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METHOD AND SYSTEM FOR DETERMINING INSULIN DOSING 
SCHEDULES AND CARBOHYDRATE-TO-INSULIN RATIOS IN DIABETIC 

PATIENTS 

5 

RELATED APPLICATION 

This application claims priority to and the benefit of provisional applications, Serial No. 
60/456,271 filed March 19, 2003, Serial No. 60/532,487 filed December 26, 2003, and 
10 Serial No. 60/543,576 filed February 1 1 , 2004. 

FIELD OF THE INVENTION 

The invention relates generally to the field of digital aids to assist in the treatment of 
15 diabetic patients who use insulin pumps or multiple dosing insulin regimens and provides 
a method for determining insulin dosing schedules in diabetic patients. 

BACKGROUND OF THE INVENTION 

20 Diabetes Mellitus has been treated for many years by insulin injection. Three recent 
advances are changing diabetes care: The Insulin Pump, new insulin formulas for 
Multiple Dose Injection, and Inhaled Insulin. These are discussed below: 

THE INSULIN PUMP: The invention of the insulin pump revolutionized diabetes care. 

25 It is a battery-powered device about the size of a pager. It contains a cartridge of insulin 
and pumps the insulin through a flexible tube into the patient via an "infusion set", which 
is a small plastic needle or "canula" fitted with an adhesive patch. The invention of the 
pump makes it possible to adopt a typical insulin regimen as follows: Basal Insulin is 
injected slowly and continuously at a rate that can be programmed to change multiple 

30 times during the day (about 4 or 5 changes per day is common). Between the changes, 
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the Basal Insulin Rate of infusion is constant. The constant periods are called "intervals". 
Additionally, boluses of insulin can be injected on command by the patient. There are 
two main types of boluses: 

5 Meal Boluses are infused just before a meal in an amount, proportional to the glycemic 
effect of the meal. This is generally proportional to the number of grams of 
carbohydrate in the meal. The proportionality constant is a personalized number called 
the Carbohydrate-to-insulin Ratio, CIR. It is used as follows: 

10 Meal Insulin Bolus = (grams of carbohydrates in the meal)/CIR (1) 

This calculation is generally performed by the patient, but there are pump models that 
can store the patient's CIR in memory and require only the grams of carbohydrate in 
the meal as the input. 

15 

Correction Boluses are infused immediately after a Blood Glucose test has been 
performed; the amount of the correction bolus is proportional to the error in the blood 
glucose concentration from the patient's personalized Target Blood Glucose. The 
proportionality constant is a personalized number called the Correction Factor, CF. It is 
20 used as follows: 

Corrective Insulin Bolus = (Blood Glucose concentration - Target)/CF (2) 

There are two types of Corrective Bolus, each with a different Target: 

25 

Time-Boundary Corrective Insulin Boluses are administered in a fasting state at the end 
of a time interval. 
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After-Meal Corrective Boluses are administered from one to five hours after a meal, 
most often within the time interval. 

Recently, pump manufacturers have been incorporating digital features in their pumps 
5 that make treatment easier. Some pumps can store the values of CF and Target and 
require only the Blood Glucose Concentration (BG) as input. Among these new digital 
features is the "Insulin-On-Board" feature. This feature mathematically models the 
amount of insulin still in the body at a given time after a bolus and recommends 
reductions to the boluses accordingly. This feature makes After-Meal Corrective Boluses 
10 more safe and practical. 

MULTIPLE DOSE INJECTION (MDI): Advances are being made in developing 
different types of insulin. Some are very long acting and non-peaking. The long-acting 
insulin can be injected as infrequently as once per day in a regimen very similar to a 

15 pump patient's basal insulin regimen. Injections of rapid-acting types of insulin can be 
given as meal and correction boluses. The two types together act as a system. These 
insulins are available in portable "pens" (named for their resemblance to writing 
implements). The pens have been mated with BG meters in "kits" in which the devices 
communicate so that the combined memory is stored in one of the two devices in the 

20 "kit". 

INHALED INSULIN: Inhaled insulin delivery systems are under development for short- 
acting insulin. It is expected that the inhalers will be combined with BG meters into 
"kits" like the ones used for MDI, then the present invention will be able to handle 
25 inhaled insulin in the same manner. This development is expected in the future. 

The nature of diabetes care is very quantitative. Ironically, the proliferation of numbers 
makes the use of lengthy algorithms on pocket calculators too time-consuming and 
therefore prohibitively expensive. The majority of endocrinologists, therefore, use 
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experience-based subjective methods. In the interest of providing greater subjective feel 
for the case at hand, endocrinologists often use the numbers to simply help them discern 
trends; then treat the trends. For instance, they commonly view the blood glucose (BG) 
scatter charts and printouts to discern trends by such subjective means as the visual 
5 density of dots on the BG scatter chart and the relative location of the areas of highest 
density. They translate these trends into insulin dose changes using their experience. 

Experienced-based and subjective methods are often not uniform from one practitioner to 
the next. Additionally, there is a shortage of endocrinologists and other diabetes 

10 specialists. Accordingly, the management of diabetes is done in a disorganized manner by 
clinicians of widely varying degrees of expertise. The result is that control of diabetes in 
most patients, while satisfactory, is not optimal. As a result of sub-optimal BG control, 
the course of diabetes can include complications involving all body systems. These 
complications are associated with premature mortality and are associated with a cost, 

15 which amounts to 19% of the health dollars to care for 6% of the population. 

BRIEF SUMMARY OF THE INVENTION 

The present invention overcomes the aforementioned disadvantages of current care, by 
20 providing a method to analyze and prescribe changes to the daily insulin-dosing schedule 
of diabetic patients using insulin pumps, multiple-dose subcutaneous injection, or inhaled 
insulin. The method divides the patient's day into selected time intervals in which 
adjustable schedules are provided for Basal Insulin dosage rates and Carbohydrate-to- 
Insulin Ratio(s) (to determine Meal Insulin doses). The time boundaries and Basal Rate 
25 changes are usually set by the Practitioner to coincide with the patient's meals. The 
patients are usually encouraged to test their Blood Glucose (BG) at the time boundaries 
just before they eat. The invention uses two systems of insulin nomenclature: 

CONVENTIONAL INSULIN NOMENCLATURE: 
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Total Daily Insulin = Prescription Insulin + Corrective Insulin 
where: Prescription Insulin = Basal Insulin + Meal Insulin 



(3) 
(4) 



5 The invention incorporates the concept of utilizing the Corrective Insulin over a selected 
time interval as an "error" in the patient's Prescription Insulin (Basal Insulin + Meal 
Insulin) for the whole day as well as for each time interval. Methods are included for 
estimating the change to one of the two components of Prescription Insulin, then 
determining the change to the other component by subtracting from the error. Therefore, 
10 there are two basic algorithmic forms, which are called "Floats": 

The Meallns Float: 

The change in Basal Insulin is estimated first; then the invention calculates the change in 
15 Meal Insulin to be the error in Prescription Insulin minus the change in Basal Insulin. 
Some of the ways for estimating the change in Basal Insulin are: 

Borrowing Basal Rate from another interval; 
Estimating Basal Rate from another algorithm (e.g. a Basal Float); 
20 Estimating change in Basal Insulin from the carb-free latter part of a time interval 

using the Time-Boundary Corrective Insulin (at the end of the interval) as the 
error indicator. The float is done on the first part of the interval, using the After- 
Meal Corective Insulin as the error 

or 

25 The Basal Float: 

The change in Meal Insulin is estimated first; then the invention calculates the change in 
Basal Insulin to be the error in Prescription Insulin minus the change in Meal Insulin. 
Some of the ways for estimating the change in Meal Insulin are: 

5 
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Borrowing Meal Insulin or CIR from another interval; 
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Estimating the change in Meal Insulin for an interval as a share of the Change in 
Total Day's Meal Insulin in the same proportion as (Carbs for the interval)/(Total 
Day's Carbs); 



Estimating the change in Meal Insulin for an interval as a share of the Change in 
Total Day's Meal Insulin in the same proportion as (Meal Insulin for the 
interval)/(Total Day's Meal Insulin). 



10 ENHANCED INSULIN NOMENCLATURE: 

Also, to provide another way of accounting for After-Meal Insulin, the invention 
identifies "Enhanced Variables" as a system of insulin nomenclature that lumps the 
After-Meal Corrective Insulin with the Meal Insulin as follows: 

15 Total Daily Insulin=Enhanced Prescription Insulin+Time-Boundary Corrective Insulin (5) 



where 



Enhanced Prescription Insulin = Basal Insulin + Enhanced Meal Insulin 



(6) 



20 



and: 



Enhanced Meal Insulin = Meal Insulin + After-Meal Corrective Insulin 



(7) 



25 The Floats are very similar: 



The Meallns Float: 
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The change in Basal Insulin is estimated first; then the invention calculates the change in 
Enhanced Meal Insulin to be the error in Enhanced Prescription Insulin minus the change 
in Basal Insulin. Some of the ways for estimating Basal Insulin are: 

5 Borrowing Basal Rate from another interval 

Estimating Basal Rate from another algorithm (e.g. a Basal Float) 

or 

10 The Basal Float: 

The change in Enhanced Meal Insulin is estimated first; then the invention calculates the 
change in Basal Insulin to be the error in Enhanced Prescription Insulin minus the change 
in Enhanced Meal Insulin. Some of the ways for estimating Enhanced Meal Insulin are: 

15 

Borrowing Enhanced Meal Insulin or CIR from another interval; 

Estimating the change in Enhanced Meal Insulin for an interval as a share of the 

Change in Total Day's Enhanced Meal Insulin in the same proportion as (Carbs 

for the interval)/(Total Day's Carbs); 
20 Estimating the change in Enhanced Meal Insulin for an interval as a share of the 

Change Total Day's Enhanced Meal Insulin in the same proportion as 

(Enhanced Meal Insulin for the interval)/(Total Day's Enhanced Meal Insulin); 



25 IN GENERAL: 

It may not be desirable to apply all of the error term to effect a change. Methods are 
included for applying a limited amount of the error in order to avoid overshoots. 

The above selection of "Float" algorithms have been developed in two main versions: 
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Daily Update Version: The Float algorithms above are embodied in a program that uses 
the previous day's data to make calculations for the present day. In this version, the full 
amounts of the error terms are not applied, but instead a predetermined fraction of the 
5 error terms are applied. If the error was valid, a reduced amount of it will show-up the 
next day. This next day's reduced error will be reduced by the same fraction and so on 
until the error disappears asymptotically. This version is especially well-suited for 
installation in insulin pumps, inhaled insulin kits, MDI injection kits, PDA's and other 
portable devices. 

10 

Multiple Days' Data Version: The Float algorithms above are embodied in a program 
that uses the recent calendar period (e.g. last few weeks) for the data source. The data are 
therefore averages. The full amounts of the error terms are not necessarily applied, but 
instead the fraction or amount of error to be applied is input by the practitioner. These 
15 versions are suitable for installation in the practitioner's computer. A sub- version of this 
version determines the error fractions automatically. It is suitable for the patients' 
computer, or a website, for use with patients who have insulin pumps, or kits for Multiple 
Daily Injection or Inhaled Insulin. 

20 The various aspects of the present disclosure may be more clearly understood and 
appreciated from a review of the following detailed descriptionof the disclosed 
embodiments and by reference to the appended figures. 

BRIEF DESCRIPTION OF THE FIGURES 

25 

Figure 1 illustrates an exemplary embodiment of the Input Form for the Multiple Days' 
Data Version for Insulin Pumps (Type D). The inner panel is the SubForm. It has two 
pages, which can be reached by scrolling. The first of these is shown. It contains single- 
valued data (not scheduled data). 
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Figure 2 illustrates an exemplary embodiment of the Input Form for the Multiple Days' 
Data Version for Insulin Pumps (Type D). The inner panel is the SubForm. It has two 
pages, which can be reached by scrolling. The second of these is shown. It contains daily 
5 schedule data. 



Figure 3 an exemplary embodiment of the source of the multiplier FinsAuto, which 
automates dRxInsAuto in the automated Multiple Days' Data Version (Automatic Digital 
Advisor) by comparing the standard deviation of the patient's BGs to the mean standard 
10 deviation from the database. If the patient's number is high, the multiplier (which is 
always < 1) is reduced. The automated change in Enhanced Prescription Insulin is 
FinsAuto times the Time-Boundary Corrective Insulin times another factor. 



15 



DETAILED DESCRIPTION OF THE INVENTION 



L TABLE OF CONTENTS 

The invention is a set of algorithms used to determine the various insulin-dosing rates, 
and Carbohydrate-to-insulin Ratio(s) that comprise the daily insulin-dosing schedule for 
a patient. The "Float Algorithms" apply to all exemplary embodiments described herein. 
20 The description, as shown in the table of contents below, is broken down first by 

"Embodiment" (pump or MDI) and then by "Version" (Daily Update or Multiple Day's 
Data) and finally by "Algorithm" ( Basal Float 1, Meal Insulin Float 1, etc). 



1. TABLE OF CONTENTS 

25 

2. SUFFIXES and TIME INDICES 



3. GLOSSARY 
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4. GENERIC DERIVATIONS 

4.1 MAKING CHANGES IN THE CARBOHDRATE-TO-INSULIN RATIO, CIR 
5 4.2 SOME IMPORTANT EQUATIONS 

4.2.1 CONVENTIONAL INSULIN NOMENCLATURE 

4.2.2 ENHANCED INSULIN NOMENCLATURE: 

10 

4.2.3 GENERAL 

4.3 THE TWO-LEVEL BASAL SYSTEM, and the Kf CALCULATOR 
15 4.3.1 STATISTICAL CORRELATION 

4.3.2 AVERAGING 

5. TYPES OF INSULIN DELIVERY SYSTEMS 

20 

6. DESCRIPTION BY, VERSION. EMBODIMENT, ALGORITHM 
6.1 VERSIONS USING DAILY UPDATE 

25 6. 1. I PRELIMINARY DERIVATIONS 

6.1.1.1 TIME INTERVALS AND CORRECTIVE INSULIN 

6.1.1.2 Krxlnsl: GOVERNS THE SIZE OF INSULIN CHANGES 

30 
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6. 1.2 FOR PUMPS (TYPE E) 
6.1.2.1 BASAL-TO-TOTAL RATIO 

5 6.1.2.2 BASAL FLOAT 1. ( deMeallns is proportional to eMeallns or Carbs) 

6.1.2.3 BASAL FLOAT 2, ( deMeallns value from outside the interval ) 

6.1.2.4 MEAL INSULIN FLOAT 1 

6.1.2.5 OVERVIEW OF 6. 1 . 1 .2 and 6. 1 . 1 .3 

6.1 .2.6 MEAL FLOAT 2 (uses AMCorlns(i) as error ) 

6. 1.3 FOR MULTIPLE DOSE INJECTION (MDI) AND INHALED INSULIN: 

6.1.3.1 BASAL FLOAT 1. (not used with MDI or Inhaled Insulin) 

6.1.3.2 BASAL FLOAT 2, ( The value of dMeallns is from outside the interval ) 
20 

6.1.3.3 MEAL INSULIN FLOAT 1 

6.1.3.4 OVERVIEW OF 6.1.3 

25 6.1.3.5 MEAL INSULIN FLOAT 2, (uses AMCorlns(i) as an error term) 

6.1.4 SKIPPED BG'S 



10 



15 
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6. 1.5 A MODIFIED BOLUS CALCULATOR 

6. 1.6 CHANGING THE PATIENTS SCHEDULE 

5 6.2 VERSIONS USING MULTIPLE-DAYS ' DATA 

6.2.1 MULTIPLE DAYS' DATA (DIGITAL ADVISOR) FOR PRACTITIONERS 
6.2.1.1 FOR PUMPS 

10 

6.2.1.1.1 PUMP TYPE D and E 

6.2.1.1.1.1 Basal Float 1 , (deMeallns is proportional to eMeallns or Carbs) 
15 6.2. 1.1.1.2 Basal Float 2, (not used with Multiple Days' Data) 

6.2.1.1.1.3 Meal Insulin Float 1 

6.2. 1.1. 1.4 Overview of 6.2. 1.1. 1.1 and 6.2.1.1.1.3 Multiple Days' Data TypeD 
20 pumps 

6.2.1.1.1.5 Meal Insulin Float 2 (uses AMCorlns as the error ) 

6.2.1.1.2 PUMP TYPE C 

25 

6.2.1.1.3 PUMP TYPE B 

6.2.1.1.4 PUMP TYPE A 
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6.2.1.2 SUBCUTANEOUS MULTIPLE DOSE and INHALED INSULIN 

6.2.1.2.1 BASAL FLOAT 1 

6.2.1.2.2 MEAL INSULIN FLOAT 1 

6.2.1.2.3 MEAL INSULIN FLOAT 2 (uses AMCorlns(i) as an error ) 

6.2.1.3 LIMITED DOMAIN OF deRxInsl and the SAFETY-NET FORMULA for 
MULTIPLE DAYS' DATA VERSIONS 

6.2.1.3.1 LIMITED DOMAIN OF deRxInsl 

6.2.1.3.2 SAFETY-NET FORMULA 

6.2.1.3.2.1 For Basal Float 1 

6.2.1.3.2.2 For Meal Insulin Float 1 

6.2.1.3.2.3 For Meal Insulin Float 2 (uses AMCorlns(i) as error ) 
6.2.2 AUTOMATIC MULTIPLE DAYS' DATA (DIGITAL ADVISOR) 

6.2.2.1 AUTOMATION OF deRxInsl 

6.2.2.2 AUTOMATION OF deMeallns 

6.2.2.3 AUTOMATIC ROUNDING OF CIR FOR PUMP TYPE A 
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6.3 NON-FLOAT ALGORITHM 
7 TIME INTERVALS 
5 7.1 FINDING THE DAY'S LAST ENTRY 



2. SUFFIXES and TIME INDICES: 

10 In the present invention, the 24 hour day is divisible into multiple time intervals. The 
boundaries of time intervals are numbered in the manner of: timeO, timel, time2, etc. 
These time boundaries will be referred to genetically as time(i), where "i" denotes "time 
index". 

15 The Time Intervals, dt(i), are found by subtracting the consecutive time boundaries. 

dt(i) - time(i+l) - time(i) (8) 

Each time interval is numbered the same as its upstream time boundary as shown above. 
20 Special mention should be made of the interval surrounding midnight. 

dtO = 24 + timel - Tmax (9) 

where Tmax is the last time boundary in the day, usually Bedtime. The method of 
25 finding Tmax is set forth in a later section. 

The time boundaries are generally defined by the changes in the Basal Rate (in pumps) or 
by average mealtimes. Practitioners often set up the patient's schedule so that the Basal 
Rate changes, mealtimes, BG tests, Corrective Insulin Boluses, and Meal Insulin Boluses 
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all occur at these time boundaries. While not mandatory, this practice is preferred for use 
with the invention. The Basal Rates are numbered the same as time intervals, thus BR1 
goes between timel and time2. 

5 The other parameters (besides Basal Rate) are identified with the exact time boundaries, 
though in practical use, the patients cannot be expected to follow such a strict schedule. 
Therefore, there is a need for another set of time periods (called "bins" to distinguish 
them from intervals), each of which envelops a time boundary. The parameters that are 
said to occur "at a time boundary" actually occur in a bin and are given the same index 

10 number as the time boundary enveloped by the bin. The tests and boluses can be sorted 
into these 'Time-Boundary bins". In the case of the Multiple Days' Data Versions, this 
is most often handled by the downloading software of the Blood Glucose Meters and 
Insulin Pumps, in which a schedule of bins can be set up. In the case of the Daily Update 
Versions, the midpoints of the primary time intervals may be used to define the 

15 boundaries of these bins. 

Note that Time-Boundary Corrective Insulin measures the insulin error in the previous 
interval, thus when calculating parameters for the ith interval, the insulin error is 
'TBCorIns(d,i+l)". 

20 

Parameters that do not follow the schedules of time intervals lack the time interval index 
integer. In the Multiple Days' Versions, these parameters lack any index at all. 

In the Daily Update Versions, all parameters are given a day's index, "d", "d-1", etc in 
25 the manner of BF(d,i) or TDD(d). 

Figure 1 and Figure 2 show the two pages of an exemplary Input Form for Version 
6.2.1.1.1, the Multiple Days' Data Version for Pump D. Figure 1 shows un-indexed 

15 
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parameters that have a single value for the Interaction. Figure 2 shows the time intervals 
containing time-interval-indexed parameters. 



The parameters that pertain to a unique date and time are denoted with the functional 
5 form: "parameter(t)". A few of these appear in the derivations herein for explanatory 
purposes, but none are used in the present invention. 

3. GLOSSARY: 

10 Average Glycemic Index (AGI): For average carbohydrates, the ratio of the grams of 
glucose entering the blood within two hours divided by the total grams of sugar in the 
carbohydrate. There are published studies for this figure. It ranges between 60% and 
90%. 
s 

15 AIM Formulas : An acronym for "Accurate Insulin Management" (See Ref 1, which is 
incorporated by reference as if fully set forth herein). A set of statistically derived 
formulas used to estimate three parameters for the patient. There are three formulas. In 
each, a constant (beginning with "K") was determined statistically: 

20 BasalAM = Kb * TDDavg ( 1 0) 

CFaim = Kef / TDDavg (1 1) 

CIRaim = Kcir * BodyWeight(lbs) / TDDavg (12) 

The values of these constants change from time to time as new research is done. 
25 The latest values (See Ref 1) are: Kb = 0.48, Kcf=1700, Kcir=2.8 

After-Meal Corrective Insulin: Corrective boluses taken after meals (post-prandially) in 
the previous day in the ith interval. (Daily Update Version) 
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AMCorIns(d-l,i): "After-Meal Corrective Insulin ": Corrective boluses taken after meals 
(post-prandially) in the previous day in the ith interval. (Daily Update Version) 

AMCorlns(i): "After-Meal Corrective Insulin for the ith time interval" The average of 
5 corrective boluses taken after meals (post-prandially) in the ith time interval. (Multiple 
Past Days Version) 

Basal Rate: The rate in (insulin units / hour) at which Basal Insulin is administered. 

10 Basal Rate Float: CIR or Meal Insulin is determined by the practitioner or by an 
estimation formula and BR is determined by subtracting the change in Meal Insulin 
(Enhanced or conventional) from the total desired change, dRxInsl (Enhanced or 
conventional). 

15 Basal(d): "Basal Insulin." Basal insulin for the current day, calculated from the basal 
rates by the invention. (Daily Update Version) 

Basal(d,i): Basal Insulin for the current day and time interval (Daily Update Version) 

20 Basal(i): Basal for the time interval (Multiple Days' Version) 

Basal: "Basal Insulin." 1. General definition: Insulin that is administered continuously 
by pump or insulin that is injected manually and stays in the body for a long time due to 
its special chemical make-up. 2. Computer variable: The current total of Basal Insulin 
25 administered during the day as calculated from the basal rates. 

SUM( Basal(i)) over the day calculated by the invention. (Multiple Days' Version) 
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BasalTot: "Basal Insulin Total." Current Basal Insulin dose programmed into the pump 
at the time of the interaction with the Practitioner. Calculated by the pump. It should 
equal Basal. (Multiple Day's Version) 

5 BG(i): Average of blood glucose tests over many days at approximately the same time 
boundary, time(i), during the day, calculated by the glucose meter's downloading 
software. (Multiple Day's Version) 

BGmean: Overall average of blood glucose tests since last interaction or in the calendar 
10 period being analyzed, obtained from the BG meter's downloading software. (Multiple 
Day's Version) 

BGpd: "BG's per day." The average number of BG tests per day in the calendar period 
being analyzed. (Multiple Day's Version) 

15 

BGsd(i): "BG standard deviation for the ith time interval" obtained from the BG meter's 
downloading software. (Multiple Day's Version) 

BGsd: "BG standard deviation," over the calendar period being studied. Obtained from 
20 the BG meter's downloading software. (Multiple Day's Version) 

BG, Blood Glucose Concentration: These tests are self-administered several times during 
the day, usually on the time boundaries. At the present state of the art, they are 
determined by placing a drop of blood on a test strip in a blood glucose meter. The meter 
25 stores the values and times in its memory. At each practitioner/patient interaction, the 
values are generally downloaded from the Blood Glucose Meter's memory by software 
that graphs the data points and calculates several values including the overall average 
denoted BGmean, and the time boundary averages, denoted BG(i). Some models of BG 
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meter are able to link to insulin pumps providing a combined and integrated download of 
data. 

Bin: A time period enveloping a Time Boundary of the primary Time Interval system. 
5 Any BG test or bolus occurring within the Bin is treated as though it occurred on the 
Time Boundary. 

Bolus: (from the Latin, ball) Insulin infused in a short elapsed time as ordered by the 
patient, as distinguished from Basal Insulin, which is infused slowly, continuously and 
10 automatically either by a pre-programmed pump or by injection of a slow-acting insulin. 

Bolus Time Period(i): Boluses are identified with Time Boundaries, but there is 
variability in the timing of them. To resolve this, a system of Bolus Time Periods is used. 
It has boundaries alternating in staggered fashion between the boundaries of the regular 
15 Basal Intervals such that any BG or Bolus falling in the Bolus Time period is 
automatically considered as occurring exactly on the regular Basal Time Boundary. 

Boli(i): "Bolus Insulin": The average sum of Meal Insulin + Corrective Insulin for a 
time interval, so called because it is administered in boluses rather than continuously. 
20 (Multiple Past Days' Version) 

BoT : "Basal over Total", Basal / TDD . 

BoT(d): "Basal over Total" Basal/TDD for the day. 

25 

BoTFbk: "Basal over Total, Feedback". A parameter in the Daily Update Versions. 
This factor, multiplied times the day's proposed insulin change, will yield the amount of 
change to Basal. 
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BoTTgt: "Basal over Total, Target." The desired value of Basal/TDD (Daily Update 
Version) 

BoTTgtRec: "Basal over Total, Target Recommended" Recommended value of BoTTgt 
5 (Daily Update Version) 

BR(d,i): "Basal Rate" for the ith time interval." Current setting for the rate at which 
Basal Insulin is delivered. The rate is programmable in the pump so that it can change 
several times during the day. (Daily Update Version) 

10 

BR(i): "Basal Rate" for the time interval." Current setting for the rate at which Basal 
Insulin is delivered. The rate is programmable in the pump so that it can change several 
times during the day. (Multiple Days' Version) 

15 BRavg: "Basal Rate Average", Basal/24 

BRavgRec: "Basal Rate Average Recommended" 

BRf: "Basal Rate, Fasting". The BR that would sustain a patient's blood glucose in the 
20 target range if no meals are consumed within 12 hours previous and if the measurement is 
not being made in the Late-Sleep Interval (to avoid the complications of the Pre-Dawn 
effect). 

BRkey: The key Basal Rate. Other Basal Rates are pegged to it. 

25 

BRlateSlp: "Basal Rate in Late-Sleep time interval". 

BRrec(i): "Basal Rate, Recommended for the ith time interval." Calculated by the 
present invention. (Multiple Past Days Version) 
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BRreliable: A set of basal rate data chosen for reliability, high frequency of associated 
BG tests, etc. Used with the Kf calculator 

5 BRrx(i): "Basal Rate, Prescription for the ith time interval." The value the Practitioner 
gives to the patient, after reviewing the case. (Multiple Past Days Version) 

BRsimilar: A set of basal rate data chosen for similarity or closeness to the fasting basal 
rate. Used with the Kf calculator 

10 

Carbohydrate-to-insulin Ratio ( see CIR): A personalized conversion constant; current 
value. 

Carb-Counting: The technique of determining meal insulin by first counting the grams 
15 of carbohydrate in the meal about to be consumed and then dividing by CIR. 

Carbm: "Carbohydrate grams modified"; Used in bolus calculators that incorporate 
exercise. 

20 Carbs: "Grams of Carbohydrate" 

CarbSh(i): "Carb Share." When used with all but pump type A, actual grams of 
carbohydrate or 15 gm "exchanges" are used. When used with pump type A, with no 
memory for Meallns(i), this parameter is the Practitioner's or Patients's estimate of the 
25 relative magnitude of carbohydrates consumed in each time interval. For pump type A 
any units are acceptable, because the parameter is only used as a percent of the total, 
CarbShTot. Example units: grams of carbohydrate (preferred), percent of the total, units 
of meal insulin (if CIR constant). (Multiple Days' Version) 
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CarbShTot: "Carb ShareTotal"; calculated as CarbShTot - sum(CarbSh(i)) 



CF: "Correction Factor." A personalized factor used to calculate Correction Boluses. 
See CorBol(t) and AIM 

5 

Change to: as in "Change to Pescription Insulin", "Change to Basal Insulin", "Change to 
Enhanced Meal Insulin". This phrase denotes a proposed change in the named quantity, 
from the last measured value to the recommended value. For the Daily Update version, 
this is the change from one day to the next. For theMultiple Days' Data Version this is 
10 the change from the average over the past calendar period to the recommended value. 
Digital variables denoting changes are preceeded by a lower-case "d" as in calculus. 

CIR(d,i): "Carbohydrate-to-insulin Ratio" The CIR for a time interval dt(i) in the current 
day. (Daily Update Version) 

15 

CIR(i): "Carbohydrate-to-insulin Ratio" The CIR for a time interval dt(i). (Multiple Past 
Days Version) 

CIR: "Carbohydrate-to-insulin Ratio". A personalized conversion constant; current 
20 value. 

CIR = (weight of carbohydrates consumed) / (insulin required to metabolize the 
carbohydrates) (13) 

25 See MealBol(t), and AIM. Calculation of this parameter is one of the chief goals of 
PumpMaster. (Multiple Past Days Version) 

CIRrec(i):"Carbohydrate4o-Insulin Ratio, recommended for a time interval" (Multiple 
Past Days' Version) 
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CIRrec:' f Carbohydrate-to-Insulin Ratio, recommended" (Multiple Past Days Version) 

CorBol(t): "Corrective Bolus at a unique date and time." The patient periodically tests 
5 his/her Blood Glucose concentration. If it is too high, the patient calculates a bolus of 
insulin by the formula: 

CorBol(t) = (BG(t) - Target) / CF (14) 

10 Where Target is the desired BG level and CF is a personalized Correction Factor. 

Corlns(i): "Corrective Insulin." The sum of CorBol(t) at all times within the interval, 
including "After-Meal" and "Time-Boundary" times. (Multiple Past Days' Version) 

15 CorIns(d,i) "Corrective Insulin." The sum of CorBol(t) at all times within the interval 
including "After-Meal" and "Time-Boundary" times during the current day. (Daily 
Update Version) 

CorTot(d): "Corrective Insulin Total." The sum of corrective insulin at all times within 
20 the current day. (Daily Update Version) 

CorTot: "Corrective Insulin Total." The average of the sum of corrective insulin at all 
times within day. (Multiple Past Day's Version) 

25 dBasalAuto: The automated version of dBasal. (Automatic Multiple Days' Version) 

dBaslToAIM: The change in Basal necessary to achieve the BasalAIM value 
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deMealIns(d,i): "Change in Enhanced Meal Insulin" for the time interval for the current 
day. (Daily Update Version) 

deMeallns(i): "Change in Enhanced Meal Insulin" for the time interval. (Multiple Past 
5 Days Version) 

deMeallns: "Change in Total Enhanced Meal Insulin." For the whole day. (Multiple 
Past Days' Version) 

10 deMeallns Auto: The automated version of dEmeallns. (Automatic Multiple Days' 
Version) 

deRxInsAuto: "Change in Enhanced Prescription Insulin, Automatic"; estimated 
automatically. (Automatic Multiple Days' Version) 

15 

deRxInsl(d,i): "change in Enhanced Prescription Insulin in a time interval of the current 
day" (Daily Update Version) 

deRxInsl(i): "change in Enhanced Prescription Insulin in a time interval" (Multiple Past 
20 Days Version) 

deRxInsl: "change in Total Day's Enhanced Prescription Insulin" (Multiple Past Days 
Version) 

25 deRxInslld(i): "change in Enhanced Prescription Insulin, large domain in the interval" 
The "Safety-Net" formula. One of two formulas for deRxInsl(i). (Multiple Days' 
Version) 
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deRxInslsd(i): "change in Total Enhanced Prescription Insulin, small domain"; One of 
two formulas for 

deRxInsl(i) for "Safety-Net" purposes. (Multiple Days' Version) 

5 

dt(i): "difference in time"; The length of the "ith" time interval 

Early-Sleep Time Interval: The time interval starting with Bedtime and ending with the 
Mid-Sleep time boundary. Most diabetic patients are encouraged not to snack at bedtime 
10 and to take a mid-sleep BG at about 3:00 AM. If this advice is followed, then the Early 
Sleep Time Interval gives a good indication of the true "inactive basal rate", BRf, that 
underlies many other time intervals. 



eMealIns(d,i): "Enhanced Meal Insulin for the time interval." The sum of the Meal 
15 Boluses plus the After-Meal Corrective Boluses during time interval dt(i) for the current 
day. (Daily Update Version) 

eMeallns(i): "Enhanced Meal Insulin for the time interval." A multiple-day average of 
the sum of After-Meal Insulin plus Time-Boundary Corrective Insulin in a time interval. 
20 (Multiple Past Days Version) 

eMealInsRec(d,i): "Enhanced Meal Insulin Recommended for the current day and time 
interval". (Daily Update Version) 

25 eMeallnsRec(i): "Enhanced Meal Insulin for the time interval, recommended". 
Calculated by the invention. (Multiple Past Days Version) 

eMeallnsTot(d): "Enhanced Meal Insulin Total for the current day" The sum of 
eMeallns(i) during the current day. (Daily Update Version) 
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eMeallnsTot: "Enhanced Meal Insulin Total." The sum of Meallns(i) plus the sum of 
After-Meal Corrective Insulin during the whole day averaged over several days. 
(Multiple Days' Version) 

5 

Enhanced: A word used to describe a certain modified variable system, in which After- 
Meal Corrective Insulin is incorporated as part of Meal Insulin. 

eRxInsl: "Total Day's Enhanced Prescription Insulin." A subset of TDD, defined as: 
10 The sum of Enhanced Meal Insulin + Basal Insulin during the day. It is usually 
"Prescription" by the practitioner. The invention proposes methods of calculating it 
automatically. 

ExerCarbs: "Exercise Carbs." The equivalent of exercise in grams of carbohydrate. 

15 

FInsAuto: A multiplier that limits dRxInsAuto. (Automatic Multiple Days' Version) 

Fixed-Meal: Another simpler technique of determining meal insulin other than carb- 
counting. It involves eating meals of fixed menu preceded by fixed amounts of insulin. 

20 

Float: An algorithm in which the change to one of the two main parameters, Emeallns or 
BR is estimated or determined by the practitioner, and the change to the other parameter 
is determined by subtracting the estimated insulin change from the total desired change in 
insulin. The "floated" parameter is the one that is determined by subtraction. 

25 

Glycemiclndex: The ratio of calories available from carbohydrates within 2 hours after 
consumption to total calories in the carbs. It is different for different types of carbs. 
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Interaction: "Patient/practitioner Interaction." An inclusive term, including person-to- 
person interactions, and telecommunication-based interactions in which the patient's 
parameters are re-adjusted. 

5 Interval: The day is divided into time intervals for the purpose of enabling a patient's 
insulin dosing to be varied throughout the day and analyzed on a time-dependent basis. 
The intervals usually are bounded at the times of the Basal Rate changes. 

Kb: A statistically-derived constant used in the formula for estimated Basal. The latest 
10 publication of the "AIM" formulas give the latest value of Kb=0.48 (Ref 1). It is used in 
the formula: 

Basal = Kb * TDDavg (15) 

15 Kef: A statistically-derived constant used in the formula for estimated CF. The latest 
publication of the "AIM" formulas (Ref 1) give the latest value of Kcir=1700 . It is used 
in the formula: 

CF = Kef/ TDDavg (16) 

20 

Kcir: A statistically-derived constant used in the formula for estimated CIR. The latest 
publication of the "AIM" formulas (Ref 1) give the latest value of Kcir=2.8 . It is used in 
the formula: 

25 CIR = Kcir*BodyWeight / TDDavg (17) 

KcirW: A constant used in the formula for estimated CIR. The latest publication (Ref 1) 
give the latest value of Kcir=500 . It is used in the formula: 
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CIR = KcirW / TDDavg 



Kcycle: A constant representing the fraction by which CorTot is intended to be reduced 
in a specified number of days (Ncycle). (Daily Update Version) 

5 

Keyb: as in "Key Basal Rate", An identifier for an interval that is considered to have 
dependable data and whose BR is also used in other intervals. 

Keyc: as in "Key CIR", An identifier for an interval that is considered to have 
10 dependable data and whose CIR is also used in other intervals. 

Kf = "K fasting"; A constant <1. The ratio of fasting basal rate to a chosen "reliable" 
basal rate 

Kf=BRf/BRreliable (19) 

15 

Kmauto: "K meals,auto"; a positive constant < =1 whose purpose is determining 
deMeallns. (Automatic Multiple Days' Version) 

Kfbk: "K Feedback", A constant in the formula for BoTFbk that adjusts the speed of 
20 convergence (days) of the Basal-to-Total Ratio to a target value. (Daily Update Version) 

Krxlnsl: a positive constant < =1 whose purpose is limiting dRxInsl. (Daily Update 
Version) 

25 KrxInslMax: The maximum allowable value of deRxInsl/TBCorTot (Multiple Days' 
Version) 

Late-Sleep Time Interval: (same as Pre-Dawn Time Inteval) The time interval starting 
with the Mid Sleep time boundary and ending with the Breakfast time boundary. This 
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time interval is characterized by the "Pre-Dawn Effect", which is a need for somewhat 
more insulin that would be normally expected. It is believed that this effect is linked to a 
release of growth hormone. This time interval is the most dependably carb-free of all the 
intervals. It would be the best candidate for the "inactive fasting basal rate" were it not 
5 for the Pre-Dawn Effect. 

Meal Insulin: Insulin taken in a "bolus" concurrently or just before consumption of 
carbohydrates. 

Meal Insulin Float: BR is determined by the practitioner or by an estimation formula, 
and Meal Insulin (enhanced or conventional) is determined by subtracting the change in 
Basal from the total desired change, dRxInsl (Enhanced or conventional). Then change 
in CIR is determined from the change in Meal Insulin (enhanced or conventional). Use 
of this type of Float allows the Basal Rates to be kept more uniform. This is a benefit if a 
patient skips a meal. 

MealBol(t): "Meal Bolus at a unique date and time." When eating, a patient calculates 
the grams of carbohydrates being consumed and calculates an insulin bolus by the 
following formula: 
20 

MealBol(t) = ( gm of carbohydrate ) / CIR (20) 
where CIR is the personalized Carbohydrate-to-insulin Ratio 
25 Meallns(d,i) = Meal insulin within a time interval (Daily Update Version) 

Meallns(i) = Meal insulin within a time interval (Multiple Past Day's Version) 
MeallnsTot = The total of meal insulin in a day 



10 



15 
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NBGs(i): "number of BG's in the time interval" over the calendar period being analyzed. 
(Multiple Day's Version) 

5 NBGs: "number of BG's. 11 Total number of BG tests in the BG meter since last 
download or in the calendar period being analyzed. (Multiple Day's Version) 

Ncycle: the number of days until a fraction Kcycle of the insulin error is removed. 
(Daily Update Version) 

10 

NDbg: "number of days of blood glucose." Number of days of BG tests in the calendar 
period being analyzed. (Multiple Day's Version) 

Peg: (verb) To set a parameter (CIR or BR) in one interval equal to a constant times the 
15 same parameter in another interval. The parameter is said to be "pegged" to the key 
interval. Normally the constant is equal to the ratio of the parameters on day of 
adjustment by the Practitioner, so that the same ratio is maintained in the future. 

Pen: A pocket-portable insulin delivery device, named for its resemblance to a writing 
20 implement. 

PmPctBGsd: The database "population" mean of the quantity (BGsd/BGmean), used in 
the automation of 

deRxInsl. (Automatic Multiple Days' Version) 

25 

Practitioner: The physician or nurse who analyzes a diabetic patient's parameters and 
prescribes insulin dose regimen. 

Pre-Dawn Time Interval: (same as Late-Sleep Time Interval) 
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PsdPctBGsd: The database "population" standard deviation of the quantity 
(BGsd/BGmean), used in the automation of deRxInsl. (Automatic Multiple Days' 
Version) 

5 

Reliable data set: A special use of the word to indicate an interval or set of data that has 
good statistics on a certain parameter, i.e. high frequency of BG testing, low Standard 
Deviation. 

10 Rxlnsl: "Total Day's Prescription Insulin." A subset of TDD, defined as: The sum of 
Meal Insulin + Basal Insulin during the day. It is prescribed by the practitioner, unlike 
Corrective Insulin. 

Similar data set: A special use of the word indicating that the data set is likely to have a 
15 parameter of a value close to one being sought statistically. 

Swtch: "Switching parameter"; A two valued parameter whose purpose is to evaluate 
deRxInsl relative to some domain limits and shift between the two "domain" equations 
for deRxInsl(i). (Multiple Days' Version) 

20 

Target: General: A number used in a feedback algorithm representing the desired result. 

TargetAM: "Target Blood Glucose After Meals". Corrective insulin is calculated 
according to how high a patient's BG is above the TargetAM. See CorBol 

25 

TargetTB: "Target Blood Glucose Before Meals". Corrective insulin is calculated 
according to how high a patient's BG is above the TargetTB. See CorBol 
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Target Basal-to-Total Ratio: The desired value of daily Basal Insulin divided by Total 
Daily Insulin. Used in a feedback algorithm. 

TBCorIns(d-l,i+l): "Time-Boundary Corrective Insulin." The patient is usually 
5 instructed to test his or her BG at the time boundaries. This parameter is the previous 
day's total of Corrective Insulin taken on or near the time boundary, time(i+l). (Daily 
Update Version) 

TBCorIns(i+l): "Time-Boundary Corrective Insulin in the (i+l)th time interval." The 
10 patient is usually instructed to test his or her BG at the time boundaries. This parameter 
is the average over several days of the total of Corrective Insulin taken on or near a time 
boundary, time(i+l). (Multiple Past Days Version) 

TBCorTot(d): "Time-Boundary Corrective Insulin Total for the current day". (Daily 
15 Update Version) 

TBCorTot: "Time-Boundary Corrective Insulin Total": The sum of TBCorlns(i) over the 
whole day. (Multiple Past Days Version) 

20 TDD(d-l): "Total Daily Dose" of insulin. The total amount of insulin a patient received 
during the previous day. (Daily Update Version) 

TDDavg: "Total Daily Dose of Insulin, average." The average of TDD for several days. 
(Multiple Past Days Version) 

25 

Time(i): The "ith" time boundary 

Time-Boundary Corrective Insulin: Corrective Insulin Boluses taken at or near a 
boundary of a time interval. Typically a BG test is taken at the time boundary (just 
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before eating if the next interval is a meal interval) and the corrective bolus is calculated 
from this BG test. 



TimeLabel(i): A short text phrase labeling each time boundary. PumpMaster offers 
5 several standard entries: Mid-Sleep, Pre-Breakfast, Pre-Lunch, Pre-Supper, Bedtime, 
Snack, and Basal Rate Change. 

Tmax: The last time boundary of a patient's day. Usually bedtime. 

10 

4. GENERIC DERIVATIONS: 

4.1 MAKING CHANGES IN THE CARBOHDRATE-TO-INSULIN RATIO, CIR: 

15 We can re-arrange the definition of CIR in two different ways, one for current conditions 
and one as a recommendation, assuming that the carbohydrates do not change: 

Carbs = CIR * Meal Insulin (2 1 ) 

20 CIRrec= Carbs / Recommended Meal Insulin (22) 

If Meal Insulin or Carbs are not known, then differential methods can be employed: 

CIRrec = CIR + dCIR (23) 

25 

We need the derivative of CIR with respect to Meal Insulin to use in the formulas below 
(the derivative is in parentheses): 

dCIR= (dCIR/dMeal Insulin) * dMeal Insulin (24) 
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And 

dMeal Insulin = dCIR / (dCIR/dMeal Insulin ) (25) 

5 

The following derivation leads to the formula for calculating dCIR, the change in CIR, 
that will produce a change d(Meal Insulin) in Meal Insulin. There are several ways to 
calculate or estimate the derivative. To obtain them, start with the definition of CIR: 

10 CK. = Carbs / (Meal Insulin) (26) 

Differentiate using calculus: 

(dCIR/dMeal Insulin) = - Carbs / (Meal Insulin) 2 (27) 

15 

Substitute equation (21) into equation (27) to obtain: 

(dCIR/dMeal Insulin) = - CIR / (Meal Insulin) (28) 

20 This is an estimate of the derivative that depends on CIR. It is possible to eliminate CIR 
from the equation by substituting a correlation from a statistical study. For example, the 
AIM correlation, (Ref 1) is used below. It says: 

CIR = Kcir * BodyWt / TDDavg (29) 

25 

where Kcir is a statistically-determined constant. 

Substitute this into equation (28) for CIR to obtain the following generic equation: 
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(dCIR/dMeal Insulin) = - ( Kcir * BodyWt / TDDavg ) / (Meal Insulin) (30) 
If Meal Insulin is unavailable, it can be calculated as: 
5 Meal Insulin = TDDavg - Basal - Corrective Insulin (31) 
Leading to: 

(dCIR/dMeal Insulin) = - ( Kcir * BodyWt / TDDavg ) / (TDDavg - Basal - Corrective 
10 Insulin) (32) 

The AIM statistical studies show that Basal is slightly less than half of TDDavg. 
Corrective Insulin is usually small, so we can say that Meal Insulin is approximately half 
of TDDavg. This leads from equation (30) to the equation: 

15 

(dCIR/dMeal Insulin) = - ( Kcir * BodyWt * 2 / TDDavg 2 ) (33) 
and finally: 

20 dCIR = - ( Kcir * BodyWt * 2 / TDDavg 2 ) * dMeal Insulin (34) 
Another correlation (Ref 2) estimates CIR= Kcirw/TDD. By similar steps this leads to: 
dCIR =-(Kcirw* 2 /TDDavg 2 )* dMeal Insulin (35) 

25 

The change in Meal Insulin, dMeallns, may be obtained as follows: 

dMeallns = MeallnsNew - MeallnsOld (36) 
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5 



15 



20 



dMeallns = Carbs * (1/CIRnew - 1/CIRold ) (37) 

or it may be input by the Practitioner. 
4.2 SOME IMPORTANT EQUATIONS: 



4.2.1 CONVENTIONAL INSULIN NOMENCLATURE 

The earlier section showing the different types of insulin is re-written below using the 
10 variable names. 

Recall the definitions: Rxlnsl: Prescription Insulin, 

TBCorTot: Total Day's Time-Boundary Corrective Insulin, 
AMCorTot: Total Day's After-Meal Corrective Insulin 
CorTot: Total Day's Corrective Insulin 



TDD = Rxlnsl + CorTot (3 8) 

Where Rxlnsl = Basal +Meallns (39) 

For small changes: 

dRxInsl = dBasal + dMeallns (40) 
Within a time interval, similar equations holds true: 



25 Rxlnsl(i) = Basal(i) + Meallns(i) (4 1 ) 

dRxInsl(i) = dBasal(i) + dMeallns(i) (42) 

The present invention incorporates the following concept: The Total Day's Corrective 
Insulin, CorTot represents an "error" in the patient's Prescription Insulin; the goal is 
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CorTot=0. The practitioner (or an automatic algorithm) decides how much of CorTot to 
eliminate. This amount is called dRxInsl mimicking the words "Change in Total 
Prescription Insulin". By making this change, the program can indirectly cause CorTot to 
be reduced in the days ahead. dRxInsl may be determined differently, depending on the 
5 Version: 

Daily Update Version: Krxlnsl is a pre-determined constant <=1 . It is used to set 
dRxInsl in the manner shown below: 

10 dMeallns + dBasal = dRxInsl = Krxlnsl * CorTot (43) 

Similarly, in the time interval: 

dMeallns(i) + dBasal(i) = dRxInsl(i) = Krxlnsl * CorIns(i+l) (44) 

15 

At the present time Krxlnsl = 0.16 for the Daily Update algorithms, but the value of 
Krxlnsl is subject to adjustment for optimum safety and performance. 

Multiple Days' Data Version: In the Manual Sub- Version, dRxInsl is input by the 
20 Practitioner for each Patient/Practitioner Interaction. Any value is allowed up to a 
maximum of KrxInslMax*CorTot, where KrxInslMax is a fractional constant: 

dMeallns + dBasal = dRxInsl <= KrxInslMax * CorTot (45) 

25 Each time interval gets its share of the "fix" in proportion to its share of the total error : 

dMeallns(i) + dBasal(i) = dRxInsl(i) = dRxInsl * (CorIns(i+l) /CorTot) (46) 
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At the present time, KrxInslMax = 0.5 but is subject to adjustment for optimum safety 
and performance. 

In the automatic Sub-version, an automatic method determines dRxInsl (explained in the 
section entitled" Automatic Multiple Days' Data (Digital Advisor)". 

The left-hand-side of equation (44) or (46) is implemented for the interval in one of two 
ways. These are given the name "floats": 

The Meallns Float: dBasal(i) is estimated first; then the invention calculates 

dMeallns(i) = dRxInsl(i) - dBasal(i). Some of the ways for 
estimating dBasal(I) are: 



Borrowing new Basal Rate from another interval; 



Estimating Basal Rate from another algorithm (e.g. a Basal 
Float); 



Estimating dBasal(i) from the carb-free latter part of a time 
interval using TBCorlns(i) as the error indicator. The float is 
done on the first part of the interval, using AMCorlns(i) as the 
error. (47) 



or 



The Basal Float: dMeallns(i) is estimated first; then the invention calculates 
dBasal(i) = dRxInsl(i) - dMeallns(i) . Some of the ways for 
estimating dMeallns(i) are: 



Borrowing Meallns(i) or CIR(i) from another interval; 
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Estimating dMeallns(i) as a share of day's total dMeallns in 
the same proportion as CarbSh(i)/CarbShTot; 

5 Estimating dMeallns(i) as a share of day's total dMeallns in 

the same proportion as MealIns(i)/MealInsTot (48) 

4.2.2 ENHANCED INSULIN NOMENCLATURE: 

10 The types of insulin-delivery systems that incorporate Insulin-on-board calculations make 
it safer for the patient to use After-Meal Corrective Insulin dosing, (variable name: 
AMCorlns) It is called "corrective" because it uses the correction formula, equation 
(14). However, since it is part of the insulin needed to cope with a specific meal of carbs, 
it is more convenient to lump it together with Meal Insulin by defining new variables: 

15 

Enhanced Meal Insulin: eMeallns = Meallns + AMCorlns 
Enhanced Prescription Insulin: eRxInsl = Basal + eMeallns 

This is explained better as follows: 
20 TDD = eRxInsl + TBCorlns (49) 

where eRxInsl = Basal + eMeallns (50) 

and eMeallns = Meallns + AMCorlns (5 1 ) 

25 

The two quantities in eMeallns are added together at the start of these calculations and 
treated as a single variable. 

For small changes: 



39 

SUBSTITUTE SPECIFICATION 



deRxInsl = dBasal + deMeallns 



(52) 



Within a time interval, similar equations holds true: 



eRxInsl(i) = Basal(i) + eMeallns(i) 



(53) 



deRxInsl(i) = dBasal(i) + deMeallns(i) 



(54) 



10 The present invention incorporates the following concept: The Total Time-Boundary 
Corrective Insulin, TBCorTot represents an "error" in the patient's Enhanced Prescription 
Insulin; the goal is TBCorTot=0. The practitioner (or an automatic algorithm) decides 
how much of TBCorTot to eliminate. This amount is called deRxInsl mimicking the 
words "Change in Total Enhanced Prescription Insulin". By making this change, the 

15 program can indirectly cause TBCorTot to be reduced in the days ahead. deRxInsl may 
be determined differently, depending on the Version: 

Daily Update Version: Krxlnsl is a pre-determined constant <=1. It is used to set 
deRxInsl in the manner shown below: 

20 

deMeallns + dBasal = deRxInsl = Krxlnsl * TBCorTot (55) 

Similarly, in the time interval: 

25 deMeallns(i) + dBasal(i) = deRxInsl(i) = Krxlnsl * TBCorIns(i+l) (56) 

At the present time Krxlnsl = 0.16 for the Daily Update algorithms, but the value of 
Krxlnsl is subject to adjustment for optimum safety and performance. 
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Multiple Days' Data Version: In the Manual Sub-Version, deRxInsl is input by the 
Practitioner for each Patient/Practitioner Interaction. Any value is allowed up to a 
maximum of KrxInslMax*TBCorTot, where KrxInslMax is a fractional constant <=1. 



Each time interval gets its share of the "fix" in proportion to its error : 
deMeallns(i) + dBasal(i) = deRxInsl(i) = deRxInsl * (TBCorIns(i+l) /TBCorTot) (58) 

10 

At the present time KrxInslMax = 0.5 but is subject to adjustment for optimum safety and 
performance. In the automatic Sub-version, an automatic method determines deRxInsl 
(explained "Automatic Digital Assistant). 

15 The left-hand-side of equation (56) or (58) is implemented for the interval in one of two 
ways. These are given the name "floats": 

The Meallns Float: dBasal(i) is estimated first; then the invention calculates 

deMeallns(i) = deRxInsl(i) - dBasal(i). Some of the ways for 
20 estimating dBasal(i) are: 



5 



deMeallns + dBasal = deRxInsl <= KrxInslMax * TBCorTot 



(57) 



Borrowing Basal(i) from another interval 



25 



Estimating Basal(i) from another algorithm 
(e.g. a Basal Float) 



(59) 



or 



The Basal Float: 



deMeallns is estimated first; then the invention calculates 
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dBasal(i) = deRxInsl(i) - deMeallns(i) Some of the ways for 
estimating deMeallns are: 

Borrowing eMeallns(i) or CIR(i) from another interval 

5 

Estimating deMeallns(i) as a share of day's total deMeallns in 
the same proportion as CarbSh(i)/CarbShTot. (60) 

Estimating deMeallns(i) as a share of day's total deMeallns in 
10 the same proportion as eMealIns(i)/eMealInsTot 

4.2.3 GENERAL 

For a given Version, the different time intervals may have different types of float. 

15 

The Basal float has the advantage that it can be used for all time intervals in the day, 
enabling easy changes to the patient's daily routine. 

The Meal Insulin Float has the advantage that Basal Rate schedule can be kept simple, 
20 and changes in eating habits can be handled by CIR which addresses the changes only if 
the person consumes carbs and takes a meal bolus. However, since the Meal Insulin 
Float can only affect the time intervals with meals in them, the Basal Float equations 
must still be used for the non-meal intervals. 

25 4.3 THE TWO-LEVEL BASAL SYSTEM, and the Kf CALCULATOR 

Some Practitioners prefer a "Two Level Basal" schedule, that assigns a single Basal Rate, 
BRf, (for BR fasting) around the clock except for the Late-Sleep time interval, just before 
waking. The Late-Sleep interval is different because of the "Pre-Dawn Phenomenon", 
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which is the requirement for somewhat more insulin during the second half of the sleep 
period. This results in the two-levels of Basal Rate: BRf and BRlateSlp. Finding BRf 
becomes an important task. 

5 A non-meal interval would be best for determining BRf. Typically, the non-meal 
intervals are the Early-Sleep and Late-Sleep intervals. However, neither of these is a 
perfect candidate: 

The Early-Sleep interval, if truly meal-free, would give the best value of BRf, but often 
patients "cheat" by taking a bedtime snack. Also, the patient must interrupt his or her 
10 sleep in order to take the necessary mid-sleep BG test, so the data is often not available. 
The Late-Sleep or pre-dawn interval is the most readily available and most often meal- 
free, but this interval is unsuitable because of the "dawn phenomenon". Neither of these 
is a perfect candidate for BRf. 

15 The present invention incorporates two generalized methods that are designed to provide 
several ways to calculate BRf. Some nomenclature should be explained: BRf is intended 
to be used in most intervals excluding a few which are called "excluded intervals". One 
interval or category of BR's with good statistical reliability may be nominated as a 
"reliable" interval (with basal rate BRreliable). Another interval or data set may be 

20 nominated as a "similar" interval because its basal rate, BRsimilar, is similar to BRf. The 
present invention uses two generic methods to obtain BRf. 

4.3.1 Statistical Correlation: 

BRf may be obtained by a familiar least squares formula that statistically correlates 
25 paired values of "reliable" and "similar" data over the recent calendar period with a 
correlation constant, Kf, estimated to fit the formula BRsimilar = Kf * BRreliable. 

Kf = SUM[ ( BRsimilar ) * (BRreliable) ] / SUM[ BRreliable 2 ] (61) 
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Once calculated, the correlation constant, Kf, is used to convert the values of the 
"reliable" basal rates into values of BRf until the next Practitioner interaction: 
BRf=BRreliable*Kf (62) 



5 4.3.2 Averaging: 

BRf may be obtained by averaging certain sets of BRsimilar data from the same day or 
the previous day (in the case of the Daily Update Version), or from the recent calendar 
period (in the case of the Multiple Days' Data Version). The smoothing effect of the 
averaging process helps to produce good values. 

10 

Some particular applications of these two methods are described below: 

The the Early-Sleep BR's of nights in which there was no bedtime snack are used as 
BRsimilar. Paired with these are values of Late Sleep BR immediately following, in 
15 the early morning of the next calendar day, which are used as BRreliable. The 

formula for subsequent use is: BRf = Kf * BRlateSlp (63) 

The average of BR's except BRlateSlp may be nominated as the similar data set, 
paired with BRlateSlp as the reliable data set. The resulting formula appears the same, 
20 as equation (63) though the Kf is different. 

The average of all BR's except BRlateSlp may be used directly as BRf. 

The average of all BR's i.e. (Basal/24) may be used directly as BRf. 

25 

The average of all BR's i.e. (Basal/24) may be nominated as the similar data set, 
paired with BRlateSlp as the reliable data set. Once again the resulting formula is the 
same as equation (63). 
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The Early-Sleep BR's of nights in which there was no bedtime snack are used as 
BRsimilar. Paired with these are "reliable" values of Basal/24. The formula for 
subsequent use is: BRf = Kf * Basal/24 (64) 



5 The average of BR's except BRlateSlp may be nominated as the similar data set, 
paired with the average of all BG's, i.e. Basal/24 as the reliable data set. The resulting 
formula is the same as (64) but Kf is different. 

The average of the Basal Float 1 results for all the other intervals (except Late-Sleep 
10 interval) may be nominated as the similar data set, paired with BRlateSlp as the 
reliable data set. Once again the resulting formula looks the same as equation (63) 

The average of the Basal Float 2 results for all the other intervals (except Late-Sleep 
interval) may be nominated as the similar data set, paired with BRlateSlp as the 
15 reliable data set. Once again the resulting formula looks the same as equation (63) 

The average of the Meal Insulin Float 2 results for all the other intervals (except Late- 
Sleep interval) may be nominated as the similar data set, paired with BRlateSlp as the 
reliable data set. Once again the resulting formula looks the same as equation (63) 

20 

Additional applications of this type are mentioned throughout the text that follows. 
General discussion of Kf: 

The Kf Calculator is particularly well-suited for the Multiple Days' Data Versions so that 
25 it will be performed external to the insulin-delivery device. It is designed to be operated 
by the Practitioner at the time of a patient/practitioner interaction. This is because it 
depends upon digital memory of a sufficient number of nights to obtain enough data 
points to calculate an accurate value for Kf. 
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5. TYPES OF INSULIN DELIVERY SYSTEMS: 



The following is a list of insulin delivery systems showing the Versions of the present 
invention applicable to each: 

5 

Type A pumps: Have memory for TDD for several days. They have memory of the 
programmed Basal schedule, Basal(i). They have no memory for CF, CIR, CIR(i), 
BG(i), MealBol(t), Meallns(i), TBCorlns, AMCorlns, CorBol(t), or Corlns(i). Therefore, 
average combined boluses for the day must be obtained by subtracting Basal from 
10 TDDavg. Example: Medtronic MiniMed Paradigm 511. 

Version 6.2. 1.1.4: which uses Multiple Days' Accumulated Data. Program 
is external to pump. 

Type B pumps: In addition to the Type A memories, these have BG(i), actual carbs for 
15 CarbSh(i); CIR(i), CF, and Combined Boluses, Boli(i). Examples: Medtronic MiniMed 
Paradigm 512 and 712. 

Version 6.2.1.1.3: which uses Multiple Days' Data. Program external to pump. 

Type C pumps: In addition to other Type B memories, these have memories for 
20 Meallns(i) and Corlns(i). Example: Deltec Cozmo. 

Version 6.2. 1.1.2: which uses Multiple Day's Data. Program external to pump. 

Type D pumps: In addition to Type C memories, these pumps have, as a minimum, 
memories for AMCorlns(i) and TBCorlns(i). 
25 Versions 6.2. 1.1.1: which uses Multiple Days' Data. Program external to pump. 

Type E pumps: Have all the parameters of the Type D pumps as a minimum and have the 
program installed internally. 

Versions 6.1.2: which uses automatic Daily Update. Program internal to pump. 
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Version 6.2.1.1.1: which uses Multiple Days' Accumulated Data. Program 
external to pump. 



Subcutaneous or Inhaled Insulin Delivery in which the insulin delivery device and the 
5 BG meter clip together into a kit or otherwise communicate with each other so that data is 
recorded digitally. 

Versions 6.1.3: which uses automatic Daily Update. Program internal to the kit. 
Version 6.2.1.2: which uses Multiple Days' Accumulated Data. Program external 
to the kit. 

10 

For the purpose of ease of presentation, these are re-organized in the Table of Contents. 
The different types of algorithm are shown as well: 

6. DESCRIPTION BY, VERSION. EMBODIMENT, ALGORITHM: 

15 

6. 1 . VERSIONS USING DAILY UPDATE: 
6.1.1 PRELIMINARY DERIVATIONS: 

20 

6.1.1.1 TIME INTERVALS AND CORRECTIVE INSULIN 
The index "d" denotes the present day. 

The index "i" denotes the "ith" time boundary or time interval (following the time 
boundary). 

25 

The Time-Boundary Corrective Insulin, TBCorIns(d,i) is the sum of corrective boluses 
occurring at the beginning of the ith interval. Each bolus needs to be identified as a 
Time-Boundary bolus, and it needs to be identified with the ith interval. This may be 
accomplished by a suitable combination of the following methods: 
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identified with the ith interval if it falls between the midpoint of the previous 
interval and the midpoint of the ith interval. 

5 identified as a Time-Boundary Corrective bolus if it comes before the Meal Bolus 

with the same index number. 

one or both of these identifications input by the patient at bolus-time, using the 
controls on the insulin-delivery device. 

10 

The After-Meal Corrective insulin AMCorIns(d,i) is the sum of corrective boluses, 
identified by a suitable combination of the following methods: 

identified with the ith interval if it falls within the ith interval. 

15 

identified as an After-Meal Corrective bolus by the fact of coming after the Meal 
Bolus for the meal that marks the start of the interval. 

one or both of these identifications input by the patient at bolus-time, using the 
20 controls on the insulin-delivery device. 

6.1.1.2 Krxlnsl: GOVERNS THE SIZE OF INSULIN CHANGES 

Suppose the operation of the invention is analyzed starting at an arbitrary starting time, 
25 when TBCorTot = TBCorTotStart. This represents an error to the invention. The 
purpose is to decrease each day's "error", TBCorTot, by a fractional amount 
KrxInsl*TBCorTot, where Krxlnsl<=l. This means that, starting with a "starting error", 
TBCorTotStart, the error should decrease in a geometric sequence. After a number of 
days, Ncycle, 
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The remaining error, TBCorTot(Ncycle) = TBCorTotStart*[l-KrxInsl] Ncycle (65) 

This remaining error approaches near-zero as Ncycle increases. The phrase "near-zero" 
can be defined by setting a reasonably small number for a Percent Remaining Error. 

5 

Percent Remaining Error = [ 1 -KrxInsl] Ncycle (66) 

For a suitable combination of Percent Remaining Error and Ncycle, the equation can be 
solved for Krxlnsl. This is done by the invention as follows: 



10 



25 



Krxlnsl = 1 - ( Percent Remaining Error (67) 



The Percent Remaining Error is set by the inventors but is subject to change. (A typical 
value is 10%). The choice of Ncycle is left to the practitioner. (A typical value is 14 
15 days). This example leads to an exemplary value of Krxlnsl=0.16 . In plain language, 
"A choice of 0.16 for Krxlnsl eliminates 90% of the error in two weeks." It is used in 
the Daily Update algorithms as follows: 

deRxInsl = Krxlnsl * TBCorTot (68) 
20 or 

dRxInsl = Krxlnsl * TBCorTot (69) 



In the interval: 

deRxInsl(i) = Krxlnsl * TBCorIns(i+l) (70) 

or 

dRxInsl(i) = Krxlnsl * TBCorIns(i+l) (71) 
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6. 1.2 FOR PUMPS (TYPE E) 



6.1.2.1 BASAL-TO-TOTAL RATIO: 

5 

The Basal(d)/TDD(d) ratio is called BoT(d) for "Basal over TDD". It is calculated every 
day. It has been determined by medical studies that certain ratios of Basal(d)/TDD(d) 
lead to better management of diabetes, a target for Basal(d)/TDD(d) ratio can be set into 
the program by the patient or practitioner. It is called BoTTgt for "Basal over TDD, 
10 Target". 

The invention contains a feedback factor to bring BoT(d) to BoTTgt. The feedback 
factor incorporates a constant Kfbk to regulate the speed of convergence: 

1 5 BoTFbk(d) = BoT(d) + Kfbk*( BoTTgt - BoT(d) )*sign(deRxInsl) (72) 

Where the resulting value is not allowed to be less than zero or greater than one. 

This factor, multiplied times the day's proposed total insulin change will yield the 
20 amount of change to Basal. The "sign" function ensures that the magnitude of the change 
is correct for the "direction" of the change. The constant Kfbk is adjusted to achieve the 
optimum speed of convergence to BoTTgt. The feedback factor is applied as follows: 

dBasal - BoTFbk(d) * deRxInsl (73) 

25 

deMeallns = (l-BoTFbk(d)) * deRxInsl (74) 

The invention provides a recommendation for BoTTgt, named BoTTgtRec, which is 
calculated as follows: 
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BoTTgtRec = 1 - 4*CarbShTot*(Average Glycemic Index)/(a statistical correlation for 
caloric intake as a function of height, weight, and other easily known patient parameters) 

5 This formula changes carbs to calories by use of the conversion factor 4, then multiplies 
by glycemic index to obtain the immediately-available calories from the carbs, then 
divides by the patient's caloric intake as estimated by body conformation. This gives the 
requirement for Meallns/TDD. Basal to Total ratio is one minus this quantity. 

10 The present versions of the invention generally do not use this concept for both dBasal 
and deMeallns in the same time interval, but instead use one of them and determine the 
other parameter by subtraction from the total, deRxInsl in the manner described in the 
definition of "Float". 

15 

6.1.2.1 BASAL FLOAT 1, ( deMeallns is proportional to eMeallns or Carbs) 

This algorithm estimates Meal Insulin using the feedback factor, BoTFbk(d). The 
Enhanced insulin nomenclature system is used. The total change in Enhanced Meal 
20 Insulin is taken from equations (70) and (74): 

deMeallns(d) = Krxlnsl * (1 - BoTFbk(d-l)) * TBCorTot(d-l) (75) 

The portion of this quantity, which is assigned to the interval is proportional to the 
25 interval's share of Enhanced Meal Insulin from the day before. This concept is applied in 
the following equation: 

deMealIns(d,i) = Krxlnsl *(1- BoTFbk(d-l)) * TBCorTot(d-l)* eMealIns(d- 
U)/eMealInsTot(d-l) (76) 
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eMealIns(d,i) = eMealIns(d-l,i) + Krxlnsl *(1- BoTFbk(d-l)) * TBCorTot(d- 

1 )*eMealIns(d- 1 ,i)/eMealInsTot(d- 1 ) (77) 



5 Using equation (22) gives: 

CIR(d,i) = CarbSh(d-l,i) / [eMealIns(d-l,i) + Krxlnsl *(1- BoTFbk(d-l)) * TBCorTot(d- 
l)*eMealIns(d-l ,i) / eMeallnsTot(d-l)] (78) 

10 As in the definition of a Basal Float, statement (60): 

BR(d,i) = BR(d-l,i) + (deRxInsl(d,i) - deMealIns(d,i))/dt(i) (79) 

Using equation (70) gives: 

15 

BR(d,i) = BR(d-l,i) + Krxlnsl * [ TBCorIns(d-l,i+l) - (l-BoTFbk(d-l))*TBCorTot(d- 
l)*eMealIns(d-l,i) / eMeallnsTot(d-l) ] / dt(i) (80) 

This algorithm can be used in all time intervals "across the board". If used in all 
20 intervals, this algorithm has the effect of maintaining the original prescribed "shape" of 
the CIR or Meallns schedule; that is, each eMealIns(d,i) is multiplied by the same factor, 
so that they rise or fall in unison. 

6. 1 .2.2 BASAL FLOAT 2, ( deMeallns value from outside the interval ) 
25 This algorithm is used in intervals where the Meallns or CIR value is borrowed from 
outside the interval (pegged to another interval.) This method is useful in non-meal time 
intervals, because meal insulin data in these intervals is not dependable enough for 
calculations. All the CIR's go up or down in proportion to the "Key CIR". The CIR 
schedule maintains the same "shape" and each CIR preserves the same ratio to the key 
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CIR that it had on the first day, d=l. The key CIR may be chosen from several sources, 
usually from a time interval that has meals and uses a Meal Float algorithm. The number 
of the key CIR interval is keyc. The Enhanced insulin nomenclature system is used. 

5 CIR(d,i) = [CIR(d-l, keyc) /CIR(1, keyc) ]*CIR(l,i) (81) 

Equation (37) is adapted as shown below. The Enhanced nomenclature system is used, 
but note that the desired change is the same in both systems: 

10 deMealIns(d,i)= dMealIns(d,i) = CarbSh(d-l,i)*[l/CIR(d,i)- l/CIR(d-l,i)] (82) 

BR(d,i) = BR(d-l ,i) + dBR(d,i) (83) 

The "Float" equation can be obtained from statement (60) as follows: 

15 

BR(d,i) = BR(d-l ,i) + (deRx!nsl(d,i) - deMeal!ns(d,i))/dt(i) (84) 



Then equation (56) is applied as follows: 



20 BR(d,i) = BR(d-l,i) + [ KrxInsl*TBCorIns(d-l,i+l) - deMealIns(d,i) ] / dt(i) (85) 

BR(d,i) = BR(d-l,i) +[ Krxlnsl * TBCorIns(d-l,i+l) - CarbSh(d-l,i)*[l/CIR(d,i)- 
l/CIR(d-l,i)]] / dt(i) (86) 

25 

6.1.2.3 MEAL INSULIN FLOAT 1 

This algorithm pegs BR to a "Key" basal rate, i.e. all the basal rates go up or down in 
proportion to the key basal rate. The Basal schedule maintains the same "shape" and 
each Basal Rate preserves the same ratio to the key basal rate that it had on the first day, 
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d=l . The key basal rate may be chosen from several sources, usually from a time interval 
that has no meals and uses a Basal Float algorithm. The key interval number is keyb. The 
Enhanced insulin nomenclature system is used. 



5 BR(d,i) = [BR(d-l , keyb) / BR(1 , keyb) ]* BR(1 , i) (87) 

The key basal rate can also be obtained from a calculation that uses the overall result of a 
Basal Float 1 algorithm, i.e. Basal(d-l) plus the correction. The formula uses d=l like 
the one above. 

10 BR(d,i) = [Basal(d-l) + BoTFbk(d-l)*KrxInsl*TBCorTot(d-l)] / Basal(l) * 

BR(l,i) (88) 

The key basal rate may also be obtained from: 

15 From a sum of basal rates over all the intervals. 

Basal(d) = SUM( BR(d,i)*dt(i) ) (89) 
BR(d,i) = [(Basal(d)/Basal(l)] * BR(1 ,i) (90) 

Whatever the source of BR(d,i), the change in Basal Rate is: 
20 dBR(d,i)= BR(d,i)-BR(d-l,i) (91) 

As in the definition of a Meal Insulin Float, statement (59): 

deMealIns(d,i) = Krxlnsl * TBCorIns(d-l ,i+l) - dBR(d,i) *dt(i) (92) 

25 deMealIns(d,i)=KrxInsl*TBCorIns(d-l,i+l)-( BR(d,i) - BR(d-l,i) )*dt(i) (93) 

eMealIns(d,i) = eMealIns(d-l,i) + Krxlnsl * TBCorIns(d-l,i+l) - (BR(d,i) - BR(d-l,i) ) * 
dt(i) (94) 



54 

SUBSTITUTE SPECIFICATION 



Paraphrasing equation (22) gives: 
CIR(d,i) = CarbSh(d-l, i) / eMealIns(d, i) 



(95) 



CIR(d,i) = CarbSh(d-l,i) / [ eMealIns(d-l,i) + Krxlnsl * TBCorIns(d-l,i+l) - (BR(d,i) - 
5 BR(d-l,i))*dt(i)] (96) 

6.1.2.4 OVERVIEW OF 6.1.1.2 and 6,1.1.3 

10 The Basal Float 2 algorithm is used in conjunction with the Meal Insulin 1 float as 
follows: 

The practitioner's latest prescription is input for the first day, d=l. This data is the 
starting point for the automatic daily update sequence. The non-meal intervals are 
provided with Basal Float 2 algorithms, pegging their CIR's to a "Keyc" interval. One of 
15 the non-meal-containing intervals is nominated as the "Keyb" Basal Rate (usually the 
Late-Sleep interval or the average Basal/24). The Basal rates in the meal-containing 
intervals are pegged to the Key Basal Rate to maintain their original ratios to the key 
basal rate. The meal-containing intervals are provided with Meal Insulin Float 
algorithms. 

20 

6.1.2.5 MEAL FLOAT 2 (uses AMCorlns(i) as error ) 

This algorithm makes use of after-meal BG testing. These tests and associated After- 
Meal Corrective Boluses divide the interval into two parts. The algorithm uses 
AMCorlns(d-U) as an "error" indicator for the first part of the interval, where the float is 
25 calculated. The value of dBasal(d-l,i) is obtained from the carb-free second part of the 
interval, which uses TBCorIns(d-l,i+l) as an error term for dBasal(d-l,i) The 
"Enhanced" insulin terminology is not used. 

Define: Timeb(d-l,i)= The time of the after-meal bolus after the ith time boundary. 
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dtb(d-U) = Time(i+1) - Timeb(d-l,i) 
dta(d-l ,i) = Timeb(d- 1 ,i) - Time(i) 



(97) 
(98) 



5 In the second part of the interval : 

BR(d,i) = BR(d-l,i) + Krxlnsl * TBCorIns(d-l,i+l) /dtb(d-l,i) 



(99) 



Having obtained Basal Rate from the second part of the interval (or another source), the 
following statement can be said of the first part of the interval: 

10 



Mealfris(d,i) = Meallns(d-l,i) + Krxlnsl *AMCorIns(d-l,i) - dBR(d,i) * dta(d-l,i) (101) 



6.1.3 FOR MULTIPLE DOSE INJECTION (MDI) AND INHALED INSULIN: 
The Basal insulin is administered in the form of long-acting insulin as infrequently as 
20 once per day. Corrective Insulin and Meal Insulin are administered as needed in the form 
of injected or inhaled short-acting insulin. This algorithm is suitable for "kits" in which 
the BG Meter and the insulin delivery device clip together or are otherwise linked, in 
order to maintain a combined digital history and a place for the program to reside. 

25 6. 1 .3. 1 BASAL FLOAT 1 . (not used with MDI or Inhaled Insulin) 

6.1.3.2 BASAL FLOAT 2, ( The value of dMeallns is from outside the interval ) 



dBR(d,i) = BR(d,i) - BR(d-l,i) 



(100) 



1 5 CIR(d,i) = CarbSh(d- 1 ,i) / Meallns(d,i) 



(102) 
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This algorithm is used in intervals where the Meallns or CIR value is borrowed from 
outside the interval (pegged to another interval.) This method is useful in non-meal time 
intervals, because meal insulin data in these intervals is not dependable enough for 
calculations. All the CIR's rates go up or down in proportion to the "Key CIR". The 
5 CIR schedule maintains the same "shape" and each CIR preserves the same ratio to the 
key CIR that it had on the day of the most recent interaction with the Practitioner, d=l. 
The key CIR may be chosen from several sources, usually from a time interval that has 
meals and uses a Meal Float algorithm. The number of the key CIR interval is keyc. The 
Enhanced insulin nomenclature system is used. 

10 

CIR(d,i) = [CIR(d-l, keyc) / CIR(1, keyc) ]* CIR(1, i) (103) 

Equation (37) is adapted as shown below. The Enhanced nomenclature system is used, 
but note that the desired change is the same in both systems: 

15 

deMealIns(d,i)= dMealIns(d,i) = CarbSh(d-l,i)*[l/CIR(d,i)- l/CIR(d-l,i)] (104) 

BR(d,i) = Basal(d-l)/24 + dBR(i) (105) 

20 from equation (54) it can be seen that: 

BR(d,i) = Basal(d-l)/24 + (deRxInsl(d,i) - deMealIns(d,i))/dt(i) (106) 

BR(d,i) = Basal(d-l)/24 + [ KrxInsl*TBCorIns(d-l,i+l) - deMealIns(d,i) ] / dt(i) (107) 

25 A non-meal interval using this algorithm (or some other suitable source) is used as the 
"reliable" data set. The resulting basal rate by equation (107) is used to determine the 
whole day's Basal. 

Basal(d) = 24 * (some conversion factor) * BR(d-l, reliable) (108) 
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A recommended practice is the use of the Late-Sleep interval as the "reliable" interval. 
The following equation is given without explanation, as it will be covered by another 
section. 

5 

Basal(d) = 24 * Kf * BR(d-l ,LateSleep) (109) 

6.1.3.3 MEAL INSULIN FLOAT 1 
10 The Enhanced insulin nomenclature system is used. This algorithm is used primarily for 
meal-containing intervals. The whole day's Basal(d) can be from a key interval's Basal 
Float calculation as in equation (109). 

dBasal(d,i) = (Basal(d) - Basal(d-l)) * dt(i) / 24 (110) 

15 

Whatever the source of Basal data, the Meal Insulin Float continues as follows: 

The present invention calculates a schedule of new CIR(d,i) values, using the equation 
below, which is similar to equation (96): 

20 

CIR(d,i) = CarbSh(d-l,i) / [ eMealIns(d-l,i) + Krxlnsl * TBCorIns(d-l,i+l) - (Basal(d) - 
Basal(d-l))*dt(i)/24 ] (111) 

25 6.1.3.4 OVERVIEW OF 6.1.3 

The day's schedule is programmed as follows: An interval ( usually a non-meal interval) 
is nominated as the "reliable" interval and is provided with a Basal Float 2 algorithm, 
with its CIR pegged to a meal interval. The BR from this "reliable" interval is used to 
determine the round-the-clock BR and the total daily Basal dose, which equals a constant 
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(e.g. Kf or a constant of that type) times BRreliable times 24. The meal-containing 
intervals are provided with Meal Insulin Float algorithms and use the same single-valued 
round-the-clock BR. The non-meal intervals other than the "reliable" interval contain no 
calculations; their CIR's are pegged to a meal interval and their BR's are the same as all 
the others. 

6.1.3.5 MEAL INSULIN FLOAT 2, (uses AMCorlns(i) as an error term) 

This algorithm makes use of after-meal BG testing. These tests and associated bolus 
divide the interval into two parts. The algorithm uses AMCorIns(d-l,i) as an "error" 
indicator for the first part of the interval, where the float is done. 
Define: Timeb(d-l,i)= The time of the after-meal bolus after the ith time boundary. 



The Basal Rates are the same in all intervals; only Basal(d) is needed. It may be obtained 
from one of several sources. 

The carb-free second part of the interval uses TBCorIns(d-l,i+l) as an error term 
for dBasal(d,i) The "Enhanced" insulin terminology is not used. In the second 
part of the interval: 

BR(d,i) = BR(d-U) + Krxlnsl * TBCorIns(d-l,i+l) /dtb(d-U) (1 14) 

This result, obtained from a single "key" interval yields Basal (d): 



dtb(d-U) = Time(i+1) - Timeb(d-l,i) 
dta(d-l,i)= Timeb(d-l,i) - Time(i) 



(112) 
(113) 



Basal(d) = [BR(d, key) / BR(1, key) ]* Basal(l) 



(115) 
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The full schedule of results from the second part of the interval, equation (115) 
may be converted to a full day's basal as follows: 

Basal(d) = SUM over i [ BR(d,i) * dt(i) ] (116) 

5 

A Basal Float 1 algorithm like version 6.1.2.1 in a "reliable" interval may be 
used to provide a round-the-clock basal rate. 

A Basal Float 1 algorithm used in an overall manner, to obtain the day's total 
10 basal: 

Basal(d) - [Basal(d-l) + BoTFbk(d-l)*KrxInsl*TBCorTot(d-l)] (117) 

Whatever the source for Basal(d), the following statement can be said of the first part of 
15 the interval: 

Meallns(d,i) = Meallns(d-l,i) + Krxlnsl *AMCorIns(d-l,i) - (Basal(d) - Basal(d-l) * 
dta(i)/24 (118) 

20 If the source is the second part of the interval, then this becomes: 

Meallns(d,i) = Meallns(d-l,i) + Krxlnsl *AMCorIns(d-l,i) - BoTFbk(d-l) 

* KrxInsl*TBCorTot(d-l)* dta(i)/24 (1 19) 

25 CIR(d,i) = CarbSh(d-U) / Meallns(d,i) (120) 
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6.1.4 SKIPPED BG'S 

Versions 1 and all sub-versions keep track of a special "virtual interval" consisting of the 
combined Early-Sleep and Late-Sleep intervals. This is for use in the event that the 
patient skips the Mid-Sleep BG test. A Basal Float calculation is kept current over this 
5 combined interval and is used to provide the basal rate for both component invervals if 
the BG test between them is skipped. This technique is used for often-skipped BG's like 
the Mid-Sleep BG just described. This technique can be used for any number of adjacent 
time intervals with skipped BG's on the boundaries. However, for seldom-skipped BG's 
it is more expedient to merely substitute BG=Target so that a zero value is calculated for 
10 Corlns(i). This causes no change and allows the previous value to remain. For this 
reason, the BG(d,i) parameters have default values of TargetAM or TargetTB until input 
is made. 

6.1.5 A MODIFIED BOLUS CALCULATOR 

15 

Many pump models provide a bolus calculator programmed inside. It performs the 
calculations in equations (20) and (14). The present invention treats exercise as a special 
adaptation of the Bolus calculator. There are input boxes for exercise in units of carbs, 
defining a new variable, ExerCarbs. The arithmetic difference between them is used as a 
20 variable Carbm shown below: 

Carbm = Carbs - ExerCarbs (121) 

This may also be used for exercise alone without carbs. The modified Bolus Calculator 
25 also can calculate Correction Boluses. They must be designated "Time-Boundary" or 
"After-Meal" by the patient to flag the memory record and to select the correct one of the 
two targets: TargetAM and TargetTB. The modified boluses (meal and correction) are 
summed. If the result is positive, the pump infuses the calculated insulin amount as an 
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ordinary bolus. If the result is negative, the pump suspends the Basal pumping for an 
amount of time calculated as follows: 



TimeOut = - NegativeBolus(t) / BR(d,i) (122) 

5 

Or it may reduce the basal for a time: 

TimeReduced = - NegativeBolus(t) / (BR(d,i) - BRreduced ) (123) 
10 6.1.6 CHANGING THE PATIENTS SCHEDULE 

Section 1.1 above has described a normal 9 to 5 day. However, patients have many 
different schedules. To allow for this, the interval type is identified for each time interval 
by a parameter IntrvlType, which can have the following values: 

15 

M for "Meal Interval" 

Kb for "keyb interval", typically the Late-Sleep interval, or other Non-Meal 

Interval in which food is never consumed. 
Kc for "keyc interval" the source of pegged CIR's 
20 S for "snack interval" in which food is occasionally consumed. 

R for "reliable" 

The adjustments to this feature are made by the Practitioner (not the patient unless it is 
with Practitioner guidance). The practitioner makes sure there is always a value of 
IntrvlType for each time interval. He or she can change this if desired. There is no 
25 restriction on the others. The present invention processes this data as follows: 

If IntrvlType=Kb, go to Algorithm 6.1.2.3, Basal Float 2 
This results in a calculation of BR(d,keyb). 
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If IntrvlType=Kc, go to Algorithm 6.1.2.4, Meal Insulin Float 4 
This results in a calculation of BR(d,keyb). 

If IntrvlType=R, go to Algorithm 6.1.2.3, Basal Float 2 
This results in a calculation of BRsimilar. 

If IntrvlType = S go to Algorithm 6.1.2.3, Basal Float 2 

IfIntrvlType = MTHEN: 

IF a Time-Boundary BG is missing, go to Algorithm 6.1.4 

IF an After-Meal Corrective Dose is present, go to Algorithm 6.1.2.6 Meal, Insulin 
Float 2 

ELSE go to Algorithm 6.1.2.4, Meal Insulin Float 1 
6.2 VERSIONS USING MULTIPLE-DAYS' DATA: 

Instead of re-adjusting the patient's parameters with the previous day's data, these 
Versions use the average accumulated data over the calendar period prior to the 
patient/practitioner interaction. The data for each time interval during the day is averaged 
separately over all the days. The day index, "d", is dropped and instead, the new 
parameters are distinguished from the current parameters as follows: Current parameters 
have no suffix. Calculated and recommended parameters have a suffix "rec". Prescribed 
parameters have suffix "rx". The "rx" parameters are input by the practitioner after 
considering the recommendations of the "rec" parameters. Parameters marked 
"Parameter(i)" are for the "ith" interval. Parameters with nothing in parentheses are non- 
scheduled parameters for which there is only one value for each patient/practitioner 
interaction. Thus "BRrec(i)" refers to the Recommended Basal Rate for the "ith" 
interval e.g. BRrecl, BRrec2 . . etc, and BRrx(i) refers to the Prescribed Basal Rates. 
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6.2.1 MULTIPLE DAYS' DATA (DIGITAL ADVISOR) FOR PRACTITIONERS 



Krxlnsl is replaced by deRxInsl/TBCorTot so 
deRxInsl(i) = deRxInsl/TBCorTot * TBCorIns(i+l) 



(124) 
(125) 



5 



Interactive Input Forms: 

An exemplary form of the present invention is a two-table Access Database. There is a 
"one-to-many" relationship between the "patients' table", Tp and the "interactions table", 
Ti. There is a digital interactive Input Form (described in more detail in section 6.2.1.1.1. 



The practitioner obtains some of the patients data by the exam or interview process. 
Other data is obtained by downloading the data from the pump and BG meter, either 
directly into the invention or by using the manufacturer's software to make printed 
copies, which are then transcribed into the invention's interactive digital input form 
15 manually. The manufacturer's downloading software normally provides a schedule of 
Bins (time periods enveloping the primary Time Boundaries) and calculates averages 
pertaining to each time boundary for several parameters including BG(i), AMCorlns(i), 
TBCorlns(i) and Meallns(i). (Recall as an example, that Meallns(i) represents the 
average of total Meal Insulin boluses within the ith Bin.) 



6.2.1.1 FOR PUMPS 
6.2.1.1.1 PUMP TYPE D and E 
25 The formulas for pumps Types D and E are the simplest, so they will be discussed first. 
Interactive Input Forms: 

The main Input Form is the outer panel in Figure 1. It collects the patient's permanent 
demographic data for table Tp. A SubForm (inner panel) collects the data from the 



10 



20 
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patient/practitioner interaction for table Ti. The Sub Form has two pages that can be 
reached by the scroll bar. The first page (Figure 1) addresses un-indexed parameters 
which have a single value for each patient/practitioner interaction. The second page 
(Figure 2) addresses the standard modal day's schedule, containing the parameters with 
5 time-interval indexes like those referred-to herein in the manner of "parameter(i)" 



6.2.1.1.1.1 Basal Float 1 , (deMeallns is proportional to eMeallns or Carbs) 
This algorithm is similar to Basal Float algorithm 6.1.2.2 for Daily Update Version. The 
10 Enhanced insulin nomenclature system is used. 

Transpose equation (52) to show that dBasal is determined by the other two parameters: 
dBasal = deRxInsl - deMeallns (126) 
dBasal(i) = deRxInsl(i) - deMeallns(i) (127) 

15 

deMeallns(i) is estimated by saying that the distribution of deMeallns among the 
intervals is proportional to the distribution of eMeallns, i.e.: 

deMeallns(i) = deMeallns * eMealIns(i)/eMealInsTot (128) 

20 

eMeallnsRec(i) = eMeallns(i) + deMeallns *eMealIns(i)/eMealInsTot (129) 
By equation (22): 

25 CIRrec(i)= CarbSh(i)/eMealInsRec(i) (130) 
CIRrec(i) = CarbSh(i)/[ eMeallns(i) + deMeallns *eMealIns(i)/eMealInsTot] (131) 
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Note that both eMeallnsRec(i) and CIRrec(i) are merely the original value times an 
across-the-board factor. In the manner of statement (60), Basal is "Floated" by 
subtracting deMeallns(i) from deRxInsl(i): 

5 BRrec(i) = BR(i) + [ deRxInsl(i) - deMeallns(i)] / dt(i) (132) 

Substituting equations (125) and (128) into this gives: 

BRrec(i) = BR(i) + [ deRxInsl/TBCorTot * TBCorIns(i+l) 
10 - deMeallns* eMealIns(i)/eMealInsTot] / dt(i) (133) 

Also calculated is the value of: BRaveRec = (Basal + deRxInsl - deMeallns ) / 24 

(134) 

15 The practitioner uses this version of the invention as follows: 

When all the patient's data has been input from downloads or otherwise, The Basal Float 
is almost ready to calculate the main goals (a schedule of recommended basal rates, 
BRrec(i) and a schedule of recommended CIRrec(i)). The practitioner needs to input at 
least two of the three quantities in equation (126). The present invention will do the rest. 

20 So, the practitioner looks over the data obtained so far, particularly TBCorTot. Then he 
or she makes a judgment as to "How much of TBCorTot do I want to add to Prescription 
Insulin as a change?" Then he or she inputs deRxInsl, which must be within the built-in 
input limits (see section: Limited Domain). Basal(i) will be "floated", so the other 
quantity needed from the practitioner is deMeallns. Before inputting he must ask 

25 himself, "When I prescribe this change, deRxInsl, how much of it do I want to assign to 
Enhanced Meal Insulin?" He can make this judgement by comparing the ratio of Basal / 
TDDavg (known as BoT in the present embodiment) to the optimum value from the AIM 
statistical studies (48% from latest publication). For instance, if Basal is too high he can 
use greater than half of deRxInsl as deMeallns. This will raise deMeallns relative to 
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deRxInsl, thus lowering Basal. There may be other considerations of a medical nature 
that may influence the practitioner's decision. The choice of deMeallns may have input 
limits. The outputs are BRrec(i), BRavgRec, and CIRrec(i) as calculated by the 
equations above. The practitioner considers these recommended values and inputs the 
5 "rx" values based upon his judgment. 



6.2.1.1.1.2 Basal Float 2, (not used with Multiple Days' Data) 

10 6.2.1.1.1.3 Meal Insulin Float 1 

This Version is similar to the Version 6.1.2.4, Meal Insulin Float. For input, it requires 
the Prescribed Basal Rates, BRrx(i), which are input by the Practitioner. The Practitioner 
may desire "advice" before inputting BRrx(i). The values of BRrec(i) and BRaveRec 
15 from the result of Version 6.2.1.1.1.1, Basal Float 1, above, are good advice, so they are 
provided on the same computer screen Input Form. The value of BRf from the Kf 
calculator is also good advice. The Enhanced insulin nomenclature system is used. 

Transpose equations (52) and (54) to show that deMeallns is determined by the other two 
20 parameters: 

deMeallns = deRxInsl -dBasal (135) 
deMeallns(i) = deRxInsl(i) - dBasal(i) (136) 

BRrx(i) = input by practitioner (137) 

25 

The "Float" is very similar to equation (93); it is set up as follows: 
Equation (124) is used to modify equation (93) with the result below: 

deMeallns(i) = (deRxInsl/TBCorTot)* TBCorIns(i+l) - (BRrx(i) - BR(i) )*dt(i) 
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(138) 



eMeallnsRec(i) = eMeallns(i) + deRxInsl/TBCorTot * TBCorIns(i+l) - (BRxx(i)-BR(i) ) 
*dt(i) (139) 
5 Using equation (22) gives: 

CIRrec(i) = CarbSh(i) / eMeallnsRec(i) 

(140) 

10 CIRrec(i) = CarbSh(i) / [eMeallns(i) + deRxInsl/TBCorTot * TBCorlns(i-H) - (BRrx(i) 
-BR(i))*dt(i)] (141) 

The Practitioner considers this schedule of CIRrec(i) and then inputs: 

1 5 CIRrx(i) = input by the Practitioner ( 1 42) 

6.2. 1.1 . L4 Overview of 6.2. 1 . 1 . 1 . 1 and 6.2. 1.1.1.3 Multiple Days' Data, Pump Type D 

Recommendations are provided for Basal Float and Meal Insulin Float on the same Input 
20 Form (see Figure 2), so that the practitioner can consider Basal Float recommendations, 
BRrec(i), BRaveRec, and BRf when filling in the prescribed BRrx(i) schedule. The Meal 
Insulin Float uses these "BRrx(i)" values as input. Then it calculates CIRrec(i) as output 
for the meal-containing intervals. Then the Practitioner fills in the blanks for CIRrx(i). 
Backtracking the discussion a little: The practitioner's choice of BRrx(i) is very 
25 influential. Discussion: 

The practitioner can use all of the BRrec(i) values as BRrx(i) if desired. This has 
the effect of changing the entire meal insulin (or CIR) schedule by the same factor 
across the board. 



68 

SUBSTITUTE SPECIFICATION 



or 



A simple basal schedule can be used to give the patient more meal-skipping 
flexibility, as mentioned earlier. For instance: 

The practitioner can use the BR's for non-meal intervals "as is". This 
probably will include the "Early-Sleep" and "Late-Sleep" intervals. 

The Practitioner can use a single carefully-judged Fasting Basal Rate, BRf, to 
underlie the meal intervals. Determining this basal rate is one of the 
Practitioner's major tasks. The BRf Calculator may be used at the 
Practitioner's discretion. 

6.2.1.1.1.5 Meal Insulin Float 2 (uses AMCorlns as the error ) 

This algorithm makes use of after-meal BG testing. These tests divide the interval into 
two parts. The algorithm uses AMCorlns(i) as an "error" indicator for the first part of 
the interval, where the float is done. The value of dBasal(i) is obtained from the carb-free 
second part of the interval, which uses TBCorIns(i+l) as an error term for dBasal(i). 
The "Enhanced" insulin terminology is NOT used. 

Define: Timeb(i)= The time of the after-meal bolus after the ith time boundary. 



dta(i) = Timeb(i) - Time(i) 
dtb(i) = Time(i+1) - Timeb(i) 



(143) 
(144) 



In the second part of the interval: 



BRrec(i) = BR(i) + Krxlnsl * TBCorIns(i+l) /dtb(i) 



(145) 
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dBR(I) = BRrec(i) - BR(i) 



(146) 



Having obtained Basal Rate from the second part of the interval (or other source), the 
following statement can be said of the first part of the interval: 

5 

MeallnsRec(i) = Meallns(i) + Krxlnsl *AMCorIns(i) - dBR(i) * dta(i) (147) 

If the second part of the interval was used, this becomes: 

1 0 MeallnsRec(i) - Meallns(i) + Krxlnsl * AMCorlns(i) 

- dta(i) * Krxlnsl * TBCorIns(i+l)/ dtb(i) (148) 

CIRrec(i) = CarbSh(i) / MealInsRec(d,i) (149) 

15 If desired, the factor Krxlnsl may be obtained from dRxInsl input by the practitioner as 
described earlier: 

Krxlnsl = dRxInsl / (AMCorTot+TBCorTot) (150) 

20 Alternatively, Krxlnsl may be replaced by two "K-factors", one for each part of the time 
interval: KrxInsAM and KrxInsTB: 

First, Basal Rate is determined from the second part of the interval: 

BRrec(i) = BR(i) + KrxInsTB * TBCorIns(i+l) /dtb(i) (151) 

25 

Then Meal Insulin is determined from the first part of the interval: 
MeallnsRec(i) = Meallns(i) + KrxInsAM *AMCorIns(i) - dta(i) * KrxInsTB* 
TBCorIns(i+l)/dtb(I) (152) 
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CIRrec(i) = CarbSh(i) / MealInsRec(d,i) 



(153) 



This alternative method may shift the Basal/TDD ratio and may be useful if such a result 
is intended. 

5 

6.2.1.1.2 PUMP TYPEC 

Pumps of these types are intermediate between Types A and D. The algorithms of 
6.2.1.1.1.1 and 6.2. 1.1. 1.3 and their overview are applicable to Type B pumps, except 
that: 

10 

TBCorlns(i) is not available, so it must be calculated by the formula: 

TBCorlns(i) = AVG over calendar period of ( (BG(t) - TargetTB)/CF) (154) 
AMCorlns(i) is not available so Meal Float 2 cannot be used. 

15 

6.2.1.1.3 PUMP TYPE B 

Pumps of these types are intermediate between Types A and C. The algorithms of 
6.2. 1.1.1.1, 6.2. 1.1. 1.3, and their Overview are applicable to Type B pumps, except that 
in addition to the limitations of Pump Type C: 

20 

Meallns(i) is not available, so dMeallns(i) is estimated by: 

dMeallns(i) = dMeallns * CarbSh(i)/CarbShTot (155) 

25 6.2.1.1.4 PUMP TYPE A 

Type A pumps are the simplest, but have complicated formulas for the reason that the 
values for the absent parameters must be calculated using estimation formulas. These 
estimation formulas add complexity. In addition to the limitations of Type B pumps, the 
Type A pumps are limited as follows: 
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Because of the lack of data, the only appropriate algorithm for Type A pumps is 
"Basal Float 1, similar to Version 6.2.1.1.1.1. 

5 There are no memories for BG(i), so values for TBCorlns(i) and AMCorlns(i) must 
be calculated from BG data downloaded from the BG meter. This data may contain 
anomalous or unused BG test results and is not as dependable as the BG data from the 
pump's memory. 

10 There are no memories for CarbSh(i), so the practitioner must estimate. The only use 
of the data is in the ratio CarbSh(i)/CarbShTot, so the units do not matter; the 
practitioner may use grams, exchanges, percent of total, units of insulin, or any other 
units proportional to Meal Insulin. 

15 The lack of good data makes CIR hard to calculate. A single CIR is calculated for 

use round-the-clock. The differential formula (34) is used: 

dCIRcalcA = [ - ( Kcir * Wt *2 / TDDavg 2 ] * deMeallns (156) 

20 A slight complication is that Type A pumps have no memory for CIR, so the patient 
must keep track of it. To make this easier for the patient, only integer (or half integer 
values for CIR < 8) are prescribed. Therefore, a two-step manual input is used: 

dCIRcalcA is calculated by the invention and appears on the screen. The practitioner 
25 rounds it to the preferred rounded quantity and puts the value back into the reverse 
equation as dCIR. Then the invention calculates: 

deMeallnsCalcA = - dCIR / ( Kcir * Wt * 2 / TDDavg 2 ) (157) 
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Then the practitioner inputs this value into the box for deMeallns. Not surprisingly, 
the resulting value of dCIRcalcA is integer-valued. The recommended value, 
CIRrecA, is automatically calculated as follows: 

5 CIRrecA = dCIRcalcA + CIR (158) 



6.2.1.2 SUBCUTANEOUS MULTIPLE DOSE and INHALED INSULIN 

10 

Manual injection patients usually use two types of insulin: 

Long-acting insulin for "basal" injections as infrequently as once per day 
Short-acting insulin for meal and correction boluses. 

15 The insulin delivery devices include "pens" and inhalers. 

There are "kits' currently being developed that consist of a BG meter that clips or links to 
an insulin-delivery device (an insulin injection "pen" or an insulin inhaler) in such a way 
that the data is shared. The BG test results are used to calculate a corrective insulin dose 
20 automatically, and the insulin delivery device is automatically set for use. Also, carbs 
can be entered manually so that Meal Insulin Boluses are similarly calculated and pre-set. 
Digital memory is available in either the meter or the insulin delivery device so that the 
combined BG and insulin history can be downloaded by the Practitioner. 

25 There are several types of insulin available. The input form contains input boxes for the 
brand names or generic names of the two types of insulin prescribed. 
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The formulas deal with basal amounts in each time interval, rather than basal rates. The 
long time-response of the long-acting insulin makes Basal Rate schedule adjustments 
impractical. 



5 6.2.1.2.1 BASAL FLOAT 1 

The partnership of Basal Float 1 and Meal Insulin Float 1 may be employed in a similar 
manner to pumps Types D and E. Similarities and differences: As in pumps the 
Practitioner inputs deRxInsl and deMeallns. The input boxes for BR(i) are replaced by a 
single box for Basal, a single BR is calculated (one twenty- fourth of Basal) . The values 

10 of BRrec(i) are shown individually as in pumps. As in pumps, a value is calculated for 
BRaveRec using equation (141). All the BRrx(i) are replaced by a single box for BRrx, 
and Basalrx is calculated (24 times BRrx). After reviewing the recommendations for 
Basal and Basal Rate, the Practitioner inputs BRrx 

15 6.2.1.2.2 MEAL INSULIN FLOAT 1 

The Meal Insulin Float 1 is similar to that used with Type D pumps. The Enhanced 
insulin nomenclature system is used. 

The value of BasalRx from the previous section (or some other source) is used as input 
20 by the Meal Insulin Float 1 algorithm. 



The present invention then calculates a schedule of recommended CIRrec(i) values, using 
25 a Meal Insulin Float. The formula is adapted from equation (96) by applying equation 



dBasal(i)= (Basalrx - Basal) * dt(i) / 24 



(159) 



(124): 



CIRrec(i) = CarbSh(i) / [ eMeallns(i) + (deRxInsl * TBCorIns(i+l)/TBCorTot - 
(BaslRx - Basal)*dt(i)/24 ] ( 



(160) 
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6.2.1.2.3 MEAL INSULIN FLOAT 2 (uses AMCorlns(i) as an error ) 



This algorithm makes use of after-meal BG testing. These tests and associated boluses 
5 divide the interval into two parts. 

Define: Timeb(i)= The time of the after-meal bolus after the ith time boundary. 

dtb(i) = Time(i+1) - Timeb(i) 
dta(i) = Timeb(i) - Time(i) 

10 

The algorithm uses AMCorlns(i) as an "error" indicator for the first part of the interval, 
where the float is calculated. A figure for BasalRx is needed. The Practitioner places it in 
an input box after reviewing the invention's calculated recommendations, which may be 
one or more of the following: 

15 

BasalRec may be obtained from the carb-free second part of the interval, which uses 
TBCorIns(i+l) as an error term for dBasal(i) The "Enhanced" insulin terminology 
is not used. In the second part of the interval: 

BRrec(i) = BR(i) + Krxlnsl * TBCorIns(i+l) /dtb(i) (163) 
20 or 

This result from a "reliable" interval may be converted to a full day's basal as 
follows: BasalRec = BRreliable*Kf * 24 (164) 

or 

BasalRec may be obtained from the sum of the results above: 
25 BasalRec = SUM over i ( BRrec(i) * dt(i)) (165) 

or 

BasalRec may be obtained from a Basal Float 1 calculation in a "reliable" interval. 
This result is converted in the same manner as equation (164) 

or 



(161) 
(162) 
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Another source of BasalRec is the total recommended Basal from a Basal Float 1 
algorithm, converted in the same manner as equation (165) 

Whatever the source for BasalRec, the Practitioner inputs BasalRx. The following 
5 statement can be said of the first part of the interval: 

MeallnsRec(i) = Meallns(i) + Krxlnsl *AMCorIns(i) - Basal * dta(i)/24 (166) 

CIRrec(i) = CarbSh(i) / MeallnsRec(i) (1 67) 

The factor Krxlnsl may be obtained from dRxInsl input by the practitioner as described 
10 earlier: 

Krxlnsl = dRxInsl / (AMCorTot +TBCorTot) (168) 

Alternatively, if the method of equation (163) is used, Krxlnsl may be replaced by two 
"K-factors", one for each part of the time interval: KrxInsAM and KrxInsTB: 
15 First, Basal Rate is determined from the second part of the interval: 

BRrec(i) = BR(i) + KrxInsTB * TBCorIns(i+l) /dtb(i) (169) 

Then Meal Insulin is determined from the first part of the interval: 
20 MeallnsRec(i) = Meallns(i) + KrxInsAM * AMCorlns(i) 

- dta(i) * KrxInsTB * TBCorIns(i+l) /dtb(i) (1 70) 

CIRrec(i) = CarbSh(i) / MealInsRec(d,i) (171) 

25 This alternative method may shift the Basal/TDD ratio and may be useful if such a result 
is intended. 
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6.2.1.3 LIMITED DOMAIN OF deRxInsl and the SAFETY-NET FORMULA for 
MULTIPLE DAYS' DATA VERSIONS 

6.2.1.3.1 LIMITED DOMAIN OF deRxInsl 

The Float formulas using Multiple Days' Data for whole intervals work only within 
5 certain limits in which the changes called for are less than TBCorTot and in the same 
direction (same sign). 

Both these conditions are contained in the requirement that 

TBCorTot / deRxInsl > 1 (1 72) 

10 If the parameters go beyond this limit then nonsensical results occur. To prevent this 
from happening and to provide a further margin of safety, there are input limits placed 
upon the parameters to prevent the Practitioner from inputting numbers out of the 
acceptable range. The input limit is in the form of the parameter KrxInslMax. The limit 
is in the form: 

15 

TBCorTot / deRxInsl >= 1 / KrxInslMax (1 73) 

If KrxInslMax <= 1, then the nonsensical results are avoided. The value of 0.5 is 
currently in use. 

20 

6.2.1.3.2 SAFETY-NET FORMULA: 

6.2.1.3.2.1 For Basal Float 1 

25 As mentioned above, the Float formulas using Multiple Days' Data work only within 
certain limits. The first line of defense is the input limits mentioned above. However, 
there may be ways to circumvent the input limits, on purpose or accidentally. To protect 
against this possibility, there is a second line of defense, the safety net formulas. Each of 
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the Float formulas actually uses two formulas for deRxInsl(i), each over a different 
domain of deRxInsl. 

Small Domain: This is the "acceptable" domain, using the formulas discussed so far. If 
5 TBCorTot/deRxInsl>l, then the formula below is used. It produces accurate results over 
its limited domain in which the changes called for are less than or equal to the Total 
Enhanced Corrective Insulin and in the same direction. It apportions to each time 
interval a small amount of the deRxInsl proportional to the time interval's share of the 
TBCorTot. Most patient/practitioner interactions are in the small domain. The "small 
10 domain" formula has been discussed earlier. It is re-written below. The suffix "sd" is 
added to the name the name to show what it is: 

deRxInslsd(i) = deRxInsl*TBCorIns(i+l)/TBCorTot (174) 

15 

Large Domain: The formula introduced below is a backup to the input limits placed upon 
deRxInsl If the desired change to deRxInsl is not in the small domain, i.e. if 
TBCorTot/deRxInsl<l, then the formula below is used. It produces a less accurate but 
safe result when the changes called for are larger than TBCorTot or in the direction 

20 opposite to TBCorTot. The right-hand side starts with the full corrective insulin for the 
time interval. Then the "overshoot" of deRxInsl over TBCorTot is apportioned among 
the time intervals, but the apportioning fraction includes Basal as well as Enhanced 
Corrective Insulin, making it a less sensitive fraction, but less exact. In its role as a 
backup to the input limits, the large domain formulas are designed never to be used. The 

25 Safety-Net formula for Type D pumps, Basal Float 1 Algorithm 6.2. 1 . 1 . 1 . 1 , is as follows: 

deRxInslld(i) = TBCorIns(i+l) + (deRxInsl - TBCorTot) *(TBCorIns(i+l) + 
Basal(i))/(TBCorTot + Basal) (175) 
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The transition between these two formulas is accomplished by a logical variable called 
Swtch, which has a value of zero (0) in the small domain and one (1) in the large domain. 



IF (TBCorTot /deRxInsl>=l) THEN Swtch=0 ELSE Swtch=l (176) 

5 

The invention accomplishes this as follows: 

Swtch = IF(TBCorTot /deRxInsl >=1,0,1) (177) 

10 Swtch helps to put the two equations together into a single equation, which is switched 
from (174) to (175) as needed. This is shown below: 

deRxInsl(i)= swtch * deRxInslld(i) + (l-swtch)*deRxInslsd(i) (178) 

15 After substituting the large and small domain formulas into this, it reduces to the 
following equation, which requires fewer computer fields: 

deRxInsl(i) = swtch*TBCorIns(i+l) + (deRxInsl - Swtch*TBCorTot)*(TBCorIns(i+l) + 
Swtch*Basal(i)) / (TBCorTot+Swtch*Basal) (179) 

20 

This equation in turn is substituted into one of the Float equations, e.g. equation (133) to 
yield the result below, which produces a schedule of recommended basal rates. 

BRrec(i) = [ Basal(i) + Swtch*TBCorIns(i+l) + (deRxInsl- 
25 Swtch*TBCorTot)*(TBCorIns(i+l)+Swtch*Basal(i))/(TBCorTot+Swtch*Basal)- 
dMealIns*CarbSh(i)/CarbShTot ] /dt(i) (1 80) 

For Pump Types A, TBCorlnsA(i) is substituted for TBCorlns(i) and TBCorTotA for 
TBCorTot in the above equation. 
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6.2.1.3.2.2 For Meal Insulin Float 1 



The same definitions of the two domains for deRxInsl are used in the Meal Insulin Float 
5 formulas, Algorithm 6.2.1.1.1.3 Leading to: 

eMeallnsRec(i) = eMeallns(i) + Swtch*TBCorIns(i+l) + ( deRxInsl - Swtch*TBCorTot ) 
*[ TBCorIns(i+l)+ Swtch*eMealIns(i) ] / [ TBCorTot + Swtch*eMealInsTot ] 
- ( BRrx(i) - BR(i) )*dt(i) (181) 

10 

This is converted to CIRrec(i) by an adaptation of equation (22): 

CIRrec(i) = CarbSh(i) / eMeallnsRec(i) (1 82) 

15 CIRrec(i) = CarbSh(i) / [ eMeallns(i) + swtch* TBCorTot + (deRxInsl - 
swtch*TBCorTot)*(TBCorIns(i+l)+ 

swtch*eMealIns(i))/(TBCorTot+swtch*eMealInsTot) - dt(i)*(BRrx(i) 

- BR(i)) ] (183) 

20 Where Swtch is the same "switching parameter" introduced earlier by equation (1 82) to 
shift the formula between two different domains. 



6.2.1.3.2.3 For Meal Insulin Float 2 (uses AMCorlns(i) as error ) 
25 Small Domain: 

Over the whole interval: 

dRxInslsd(i) = [dRxInsl / (AMCorTot +TBCorTot)] * (AMCorlns(i) + 
TBCorlns(i)) (184) 
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This can be thought of as an equation in two parts: 



For the last part of the interval: 

dRxInslsdb(i) = [dRxInsl / (AMCorTot +TBCorTot)] * TBCorlns(i) = 

dBasalb(i) (185) 

Note that this is all Basal Insulin. 

For the first part of the interval: 

dRxInslsda(i) = [dRxInsl / (AMCorTot +TBCorTot)] * AMCorlns(i) (1 86) 



Large Domain: 

For the last part of the interval: 

dRxhislldb(i) = TBCorlns(i) +(dRxInsl - AMCorTot -TBCorTot)* 

( TBCorIns(i)+ BR(i)*dtb(i))/( AMCorTot +TBCorTot + Basal) (1 87) 

For the first part of the interval: 

dRxInsllda(i) = AMCorlns(i) +(dRxInsl - AMCorTot -TBCorTot)* 

( AMCorlns(i) + BR(i)*dta(i))/(AMCorTot +TBCorTot + Basal) (188) 

The sum of the two corrective insulin totals must be used in the switch parameter. 
Swtchm = IF((AMCorTot + TBCorTot) /dRxInsl >=1 ,0, 1) (1 89) 
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6.2.2 AUTOMATIC MULTIPLE DAYS' DATA (DIGITAL ADVISOR) 
The descriptions so far in Version 2 describe the "manual" version of the Multiple Past 
Days' algorithm. The automatic features described below are to remove the pauses for 
human judgement and input. 

5 

6.2.2.1 AUTOMATION OF deRxInsl: 

To automate the parameter deRxInsl, the present invention makes use of the fact that it is 
more difficult to control the diabetes of a patient whose BG tests, have a high percent 
standard deviation, (BGsd/BGmean) compared to the database norm. The present 
10 invention uses a simple ramp function for this as shown below: 

Some new parameters: 

Fins Auto is a multiplier for use in the formula for deRxInsAuto as follows: 
deRxInsAuto=FInsAuto * KrxInslMax*TBCorTot (1 90) 

15 

where 

KrxInslMax is a positive constant <=1, introduced earlier. It is subject to change by 
the programmers if necessary. The present value is 0.5. 

20 

Two definitions: 

PmPctBGsd: Database "population" mean of the quantity (BGsd/BGmean) . 
PsdPctBGsd: Database "population" standard deviation of the quantity (BGsd/BGmean), 
25 i.e. the database standard deviation of the personal standard deviations. 

In the present invention, Fins Auto is a ramp function as follows: 

IF BGsd/BGmean < PmPctBGsd + PsdPctBGsd then FInsAuto = 1 
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IF PmPctBGsd + PsdPctBGsd <= BGsd/Bgmean < =PmPctBGsd + 2 PsdPctBGsd, 

THEN FInsAuto = [ 1 - (BGsd/Bgmean - PmPctBGsd - PsdPctBGsd) / PsdPctBGsd ] 
IF BGsd/BGmean > PmPctBGsd + 2 PsdPctBGsd then FInsAuto = 0 (191) 

5 This function describes a flat region followed by a ramp down to zero 
as shown in Figure 3. 

6,2.2.2 AUTOMATION OF deMeallns: 

The present invention makes use of the parameter dBslToTgt, which is a general advisory 
10 parameter that shows what change in Basal is necessary to achieve BoTTgt. 

dBslToTgt = TDD * BoTTgt - Basal ( 1 92) 

Two steps are employed to automate dMeallns: 

15 

The first equation below assigns to the change an absolute value equal to the minimum 
absolute value of deRxInsl or dBaslToTgt. The reason is to avoid overshooting either 
BoTTgt or deRxInsl. The second equation uses the result from the first, together with 
equation (57), to calculate a max value for deMeallns Auto; then it limits deMeallnsAuto 
20 to Kmauto times its max value if it is positive (in the direction of adding insulin). The 
parameter Kmauto is subject to adjustment by the programmers. 

dBasalAuto = IF[ABS(dBaslToTgt/deRxInsl) <1, ABS(dBaslToTgt), 
ABS(deRxInsl)] *sgn(dBaslToTgt) ( 1 93) 

25 

deMealInsAuto=IF[(deRxInsl>dBasalAuto,Kmauto*(deRxInsl-dBasalAuto), (deRxInsl- 
dBasalAuto)] (194) 

where Kmauto is a positive constant < =1, presently set at 1. 
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The value of BoTTgt may be obtained from the AIM study's value for Kb or from 
BoTTgtRec from Section 6.1.2.1 Basal-to-Total Ratio 

5 6.2.2.3 AUTOMATIC ROUNDING OF CIR FOR PUMP TYPE A: 

In the manual mode for Type A, a two-step process is required to obtain a half-integer 
value for CIR in the range below 8. The automatic feature accomplishes this by 
multiplying the floating point number dCIRcalcA by two, then rounding off to a whole 
number, and then dividing by two. The result is input into the reverse equation to correct 
10 the dMeallns for the change. 

6.3 NON-FLOAT ALGORITHM 

This algorithm uses the BoTFbk(d) factor to determine both Basal Rate and CER. This 
15 type of algorithm is shown below in a Daily Update Version: 

eMealIns(d,i) = eMealIns(d-l,i) + KrxInsl*(l-BoTFbk(d-l))* 

TBCorIns(d-l,i+l) (195) 

20 CIR(d,i) = CIR(d-l,i) - KrxInsl*(l-BoTFbk(d-l)) * eCorIns(d-l,i+l) * CIR(d- 

l,i)/eMealIns(d-l,i) (196) 

BR(d,i) = BR(d-l,i) + KrxInsl*BoTFbk(d-l)*TBCorIns(d-l,i+l) (197) 

25 This method has the advantage of being very accurate, but has the disadvantage of 
assigning large changes in meal insulin to time intervals that have little to no carb 
consumption. For this reason, the version is suitable only for the intervals containing the 
main meals. 
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7. TIME INTERVALS: 

Theoretically, there should be no limit on the number of time intervals in the day. 
However, for reasons of screen space, there is a limit on the number of time intervals that 
may be used. Also, for an individual patient, fewer than the screen's maximum may be 
5 used. The invention needs to find the last one. The last time boundary of the day (before 
midnight) is called Tmax. It is found by a routine that picks out the time boundary with 
the highest 24-hour clock time. This routine is incorporated into a single formula of 
nested IF statements shown below, (note: In MS Access the NZ function makes nulls 
and zeros act the same): 

10 

Tmax= 

IIf(NZ([Timel])>NZ([Time2]),[Timel],IIf(NZ([Time2])>NZ([Time3 
Time3])>NZ([Time4]),[Time3],IIf(NZ([Time4])>NZ([Time5]),[Time4],IIf(N^ 
>NZ([Time6]),[Time5],nf(NZ([Time6])>NZ([Time7]),[Time6],[Time7]))) (198) 

15 

The Time Intervals, dt(i), are found by subtracting the consecutive time boundaries. 

dt(i) = time(i+l) - time(i) copy of (4) 

Special mention should be made of the interval surrounding midnight. 
20 dtO = 24 + timel - Tmax copy of (5) 



7.1 FINDING THE DAY'S LAST ENTRY 

25 Since people rarely go to bed exactly at midnight, it often occurs that some parameters 
normally associated with bedtime affect the early morning time interval. For instance, 
Meal Insulin taken at bedtime affects the Corrective Insulin of the mid-sleep time 
boundary. The formula below will find the last entry of the day: 
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[MeallnsLast] = IIF([Time2]=[Tmax], [MealIns2],0)+IIF([Time3]=[Tmax],[MealIns3],0) 
+IIF([Time4]=[Tmax],[MealIns4],0) + IIF([Time5]=[Tmax],[MealIns5],0) + 
IIF([Time6]=[Tmax],[MealIns6],0) + IIF([Time7]=[Tmax],[MealIns7],0) (199) 

5 The recommended values for the last time interval in the day need to be re-located on the 
screen. The following is an example using Recommended Basal Rate, BR: 

BRrec(i) = IIF([Time(i)] = [Tmax], [BRrecLast], [BRrec(i) regular formula]) (200) 

10 Other alternative embodiments will become apparent to those skilled in the art to which 
an exemplary embodiment pertains without departing from its scope and spirit. 
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ADDENDUM A 



SQL listing for Multiple Day's Data Version for Insulin Pumps (Type C). This Version 
of the Invention is embodied in a Microsoft Access database for use by the Practitioner as 
5 he/she interacts with a patient. 

******************************* **** 

SELECT TI.Tp_PatientID, TP.SSN, TP.Name, TP.Endo, TP.DOB, TP.Sex, 
TP.OnsetDMdate, TP.PumpStartDate, TP.PhoneNos, TP.Email, 

10 

TLIntractionlD, TI.IntrDate, 

TI.Hgt, TLWt, TI.HbAlc, Tl.Creatinine, TI.Microalb, 
TLBGmean, TLBGsd, TI.BGpd, TI.NBGs, 

15 TI.TDDa, TI.TDDb, TI.TDDc, TI.TDDd, TI.TDDe, TI.TDDf, 

(NZ([TDDa])+NZ([TDDb])+NZ([TDDc])+NZ([TDDd])+NZ([TDDe])+NZ([TDDfJ))/(- 
IsNumeric([TDDa])-IsNumeric([TDDb])-IsNumeric([TDDc])-IsNumeric([TDDd])- 
IsNumeric([TDDe])-IsNumeric([TDDfJ)) AS TDDavg, 

20 [Basal]/[TDDavg] AS BasalOvrTDD, 
0.48* [TDDavg] AS BasalATM, 
[BasalAIM]-[Basal] AS dBslToAIM, 
TI.Basalrx, 

TLTargetBG, TI.TargetBGrx, 
25 TI.CF, 1 708/[TDDavg] AS CFaim, TLCFrx, 
TI.CIR, 2.81*[wt]/[TDDavg] AS CIRaim, 

IIf([sex]="m",(([Hgt]-60)*6+106)*13/8,(([Hgt]-60)*5+100)*13/8) AS [Carbspd(Hgt)], 
l-[CarbShTot]*0.8/[Carbspd(Hgt)] AS BoTTgtRec, 
[CarbShTot]/[eMealInsTot] AS [CIR(carb)], TI.MeallnsTotARx, 
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[CarbShTot]/[MealInsTotARx] AS [CIR(MeallnslRx)], 
TLTypelnsShort, TI.TypelnsLong, 
TI.Diet, TI.PumpType, Tl.iComment, 



5 TI.TimeLabl2, TI.TimeLabB, TI.TimeLabW, TI.TimeLabl5, TI.TimeLabl6, 
TI.TimeLabl7, TI.TimeLabl8, 

0 AS Timel, TI.Time2, TI.Time3, TI.Time4, TI.Time5, TI.Time6, TI.Time7, TI.Time8, 

10 IIf(NZ([Time2])>NZ([Time3]),[Time2],nfi(NZ([Time3])>NZ([Time4]),[Time3] 

Time4])>NZ([Time5]),[Time4],nf(NZ([Time5])>NZ([Time6]),[Time5]JIf(NZ([Time6]) 
>NZ([Time7]),[Time6],nf(NZ([Time7])>NZ([Time8]),[Time7],[Time8])))))) AS Tmax, 

TI.CarbSh2, TI.CarbSh3, TI.CarbSh4, TI.CarbSh5, TI.CarbSh6, TI.CarbSh7, 
15 TI.CarbSh8, 

NZ([CarbSh2])+NZ([CarbSh3])+NZ([CarbSh4])+NZ([CarbSh5])+NZ([CarbSh6])+NZ([ 
CarbSh7])+NZ([CarbSh8]) AS CarbShTot, 

IIf([Time2]=[Tmax],[CarbSh2],0)+nf([Time3]=[Tmax],[CarbSh3],0)+IIf([Time4]=[Tma 
20 x],[Carbsh4],0)+IIf([Time5]=[Tmax],[CarbSh5],0)+IIf([Time6]=[Tmax],[CarbSh6],0)+II 
f([Time7]=[Tmax],[CarbSh7],0)+NZ([CarbSh8]) AS CarbShLast, 

TI.MealIns2, TI.MealIns3, TI.MealIns4, TI.MealIns5, TI.MealIns6, TI.MealIns7, 
TI.MealIns8, 

25 

TI.AMCorIns2, TI.AMCorIns3, TI.AMCorIns4, TI.AMCorIns5, TI.AMCorIns6, 

TI.AMCorIns7, 

TI.AMCorIns8, 
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TI.TBCorIns2, TI.TBCorIns3, TI.TBCorIns4, TI.TBCorIns5, TI.TBCorIns6, 
TI.TBCorIns7, TI.TBCorIns8, 

NZ([TBCorIns2])+NZ([TBCorIns3])+NZ([TBCorIns4])+NZ([TBCorIns5])+NZ([TBCor 
Ins6])+NZ([TBCorIns7])+NZ([TBCorIns8]) AS TBCorTot, 

[MealIns2]+[AMCorIns2] AS eMealIns2 
[MealIns3]+[AMCorIns3] AS eMealIns3 
[MealIns4]+[AMCorIns4] AS eMealIns4 
[MealIns5]+[AMCorIns5] AS eMealIns5 
[MealIns6]+[AMCorIns6] AS eMealIns6 
[MealIns7]+[AMCorIns7] AS eMealIns7 
[MealIns8]+[AMCorIns8] AS eMealIns8 

NZ([eMealIns2])+NZ([eMealIns3])+NZ([eMealIns4])+NZ([eMealIns5])+NZ([eMealIns 
6])+NZ([eMealIns7])+NZ([eMealIns8]) AS eMeallnsTot, 

IIf([Time2]=[Tmax],NZ([eMealIns2]),0)+IIf([Time3]-[Tmax],NZ([eMealIns3]),0)+IIf([ 
Time4]=[Tmax],NZ([eMealIns4]),0)+IIf([Time5]=[Tmax],NZ([eMealIns5]),0)+IIf([Tim 
e6]=[Tmax],NZ([eMealIns6]),0)+IIf([Time7]=[Tmax],NZ([eMealIns7]),0)+NZ([eMealIn 
s8]) AS eMeallnsLast, 

[Time2]+24-[tmax] AS dtO, 
IIf(NZ([Time2])>0,[time2]-[timel],0) AS dtl, 
IIf(NZ([Time3])>0,[time3]-[time2],0) AS dt2, 
IIf(NZ([Time4])>0,[time4]-[time3],0) AS dt3, 
IIf(NZ([Time5])>0,[time5]-[time4],0) AS dt4, 
IIf(NZ([Time6])>0,[time6]-[time5],0) AS dt5, 
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IIf(NZ([Time7])>0,[time7]-[time6],0) AS dt6, 
IIf(NZ([Time8])>0,[time8]-[time7],0) AS dt7, 

TI.BR1, TI.BR2, TI.BR3, TI.BR4, TI.BR5, TI.BR6, TI.BR7, TI.BR8, 

5 

[BRl]*[dtO] AS BaslO, 
[BR2]*[dt2] AS Basl2, 
[BR3]*[dt3] AS Basl3, 
[BR4]*[dt4] AS Basl4, 
10 [BR5]*[dt5] AS Basl5, 
[BR6]*[dt6] AS Basl6, 
[BR7]*[dt7] AS Basl7, 

NZ([Basl7])+NZ([Basl6])+NZ([Basl5])+NZ([Basl4])+NZ([Basl3])+NZ([Basl2])+NZ([B 
15 aslO]) AS Basal, 

TI.BG2, TI.BG3, TI.BG4, TI.BG5, TI.BG6, TI.BG7, TI.BG8, 

TI.CIR1, TI.CIR2, TI.CIR3, TI.CIR4, TI.CIR5, TI.CIR6, TI.CIR7, TI.CIR8, 

20 

IIf([Time2]-[Tmax],[Cm],0)+IIf([Time3]=[Tmax],[CIR3],0)+IIf([Time4]=[Tma^ 
R4],0)+nf([Time5]=[Tmax],[CIR5],0)+IIf([Time6]=[Tmax],[CIR6],0)+IIf([Time7]=[Tm 
ax],[CIR7],0)+NZ([ClR8]) AS CIRLast, 

25 

TI.deRxInsl, 
TI.deMeallns, 

[deRxInsl]-[deMealIns] AS dBasal, 

[CarbShTot]/([eMealInsTot]-[BasalRxTot] + [BasTot] - [dRxInsl] AS CIRecC, 
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TI.CIRrx, 

IIf(0<=[deRxInsl]/[CorTot]<=l,0,l) AS swtch, 

([BaslO]+[swtch]*[TBCorIns2]+([deRxInsl]- 

[swtch] * [TBCorTot])*([TBCorIns2]+[swtch]* [BaslO]) 

/([TBCorTot]+[swtch]*[BaslTot])-[deMealIns]*[eMealInsLast]/[eMealInsTot])/[dtO] AS 
BRrecAO, 

[BRrecAO] AS BRrecAl, 

([Basl2]+[swtch]*[TBCorIns3]+([deRxInsl]- 
[swtch]*[TBCorTot])*([TBCorIns3]+[swtch]*[Basl2]) 

/([TBCorTot]+[swtch]*[BaslTot])-[deMealIns]*NZ([eMealIns2])/[eMealInsTot])/[dt2] 
AS BRrecA2, 

([Basl3]+[swtch]*[TBCorIns4]+([deRxInsl]- 
[swtch]*[TBCorTot])*([TBCorIns4]+[swtch]*[Basl3]) 

/([TBCorTot]+[swtch]*[BaslTot])-[deMealIns]*NZ([eMealIns3])/[eMealInsTot])/[dt3] 
AS BRrecA3, 

([Basl4]+[swtch]*[TBCorIns5]+([deRxInsl]- 
[swtch]*[TBCorTot])*([TBCorIns5]+[swtch]*[Basl4]) 

/([TBCorTot]+[swtch]*[BaslTot])-[deMealIns]*NZ([eMealIns4])/[eMealInsTot])/[dt4] 
AS BRrecA4, 

([Basl5]+[swtch]*[TBCorIns6]+([deRxInsl]- 
[swtch]*[TBCorTot])*([TBCorIns6]+[swtch]*[Basl5]) 

/([TBCorTot]+[swtch]*[BaslTot])-[deMealIns]*NZ([eMealIns5])/[eMealInsTot])/[dt5] 
AS BRrecA5, 
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([Basl6]+[swtch]*[TBCorIns7]+([deRxInsl]- 

[swtch] *[TBCorTot])*([TBCorIns7]+[swtch]* [Basl6]) 

/([TBCorTot]+[swtch]*[BaslTot])-[deMealIns]*NZ([eMealIns6])/[eMealInsTot])/[dt6] 
AS BRrecA6, 

([Basl7]+[swtch]*[TBCorIns8]+([deRxInsl]- 
[swtch]*[TBCorTot])*([TBCorIns8]+[swtch]*[Basl7]) 

/([TBCorTot]+[swtch]*[BaslTot])-[deMealIns]*NZ([eMealIns7])/[eMealInsTot])/[dt7] 
AS BRrecA7, 

TI.BRrxl, TI.BRrx2, TI.BRrx3, TI.BRrx4, TI.BRrx5, TI.BRrx6, TI.BRrx7, TI.BRrx8, 
OAS TimeRxl, 

TI.TimeRx2, TI.TimeRx3, TI.TimeRx4, TI.TimeRx5, TI.TimeRx6, TI.TimeRx7, 
TI.TimeRx8, 

IIf(NZ([TimeRx2])>NZ([TimeRx3]),[TimeRx2],nf(NZ([TimeRx3])>NZ([TimeRx4]),[Ti 
meRx3]JIf(NZ([TimeRx4])>NZ([TimeRx5]),[TimeRx4],nf(NZ([TimeRx5])>NZ([Time 
Rx6]),[TimeRx5],nf(NZ([TimeRx6])>NZ([TimeRx7]),[TimeRx6],IIf(NZ([TimeRx7])> 
NZ([TimeRx8]),[TimeRx7],[TimeRx8])))))) AS TRxmax, 

nf(NZ([TimeRx2])>0,[TimeRx2]+24-[Trxmax],0) AS dTrxO, 
IIf(NZ([TimeRx2])>0,[TimeRx2]-[TimeRxl],0) AS dTrxl, 
IIf(NZ([TimeRx3])>0,[TimeRx3]-[TimeRx2],0) AS dTrx2, 
IIf(NZ([TimeIbc4])>0,[TimeRx4]-[TimeRx3],0) AS dTrx3, 
IIf(NZ([TimeRx5])>0,[TimeRx5]-[TimeRx4],0) AS dTrx4, 
IIf(NZ([TimeRx6])>0,[TimeRx6]-[TimeRx5],0) AS dTrx5, 
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IIf(NZ([TimeRx7])>0,[TimeRx7]-[TimeRx6],0) AS dTrx6, 
IIf(NZ([TimeRx8])>0,[TimeRx8]-[TimeRx7],0) AS dTrx7, 

[CarbShLast]/([eMealInsLast]+[deRxInsl]*[TBCorIns2]/[TBCorTot]-([BRrxl]- 
[BRl])*[dtO])AS CIRrecO, 

[CarbSh2]/([eMealIns2]+[deRxInsl]*[TBCorIns3]/[TBCorTot]-([BRrx2]-[BR2])*[dt2]) 
AS dRrec2, [CarbSh3]/([eMealIns3]+[deRxInsl]*[TBCorIns4]/[TBCorTot]-([BRrx3]- 
[BR3])*[dt3]) AS CDRrec3, 

[CarbSh4]/([eMealIns4]+[deRxInsl]*[TBCorIns5]/[TBCorTot]-([BRrx4]-[BR4])*[dt4]) 
AS CIRrec4, [CarbSh5]/([eMealIns5]+[deRxInsl]*[TBCorIns6]/[TBCorTot]-([BRrx5]- 
[BR5])*[dt5]) AS CIRrec5, 

[CarbSh6]/([eMealIns6]+[deRxInsl]*[TBCorIns7]/[TBCorTot]-([BRrx6]-[BR6])*[dt6]) 
AS CIRrec6, [CarbSh7]/([eMealIns7]+[deRxInsl]*[TBCorIns8]/[TBCorTot]-([BRrx7]- 
[BR7])*[dt7]) AS CIRrec7, 

TI.eMeallnsRxl, TI.eMealInsRx2, TI.eMealInsRx3, TI.eMealInsRx4, TI.eMealInsRx5, 
TI.eMealInsRx6, TI.eMealInsRx7, 

TLCIRrxl, TI.CIRrx2, TI.CIRrx3, TI.CIRrx4, TI.CIRrx5, TI.CIRrx6, TI.CIRrx7, 
TI.CIRrx8, TI.InptFormType 

FROM TP INNER JOIN TI ON TP.PatientID = TI.Tp_PatientID 
ORDER BY TLIntrDate DESC; 
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